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PREFACE 
HOW TO USE THIS MANUAL 



Welcome to the world of SPI financial modeling. As a guide 
through the LogiCalc program, this manual has been designed with one 
purpose in mind: to allow you maximum benefit from your computer 
system with the minimum amount. of effort. Toward attaining this goal 
the manual has been divided into three main sections. 

The first section presents some introductory information and 
outlines what you will need in order to be able to work with SPI's 
LogiCalc. Section II is a step by step tutorial introduction to all of 
the features of the LogiCalc program. We have attempted to organize 
the features more or less in the order you would use them as you were 
learning the program - the most basic features are presented first and 
the more specialized and complex features are described later. This is 
the main section which will be useful to you as you are first learning 
the LogiCalc program. 

The last section in the manual includes the appendices, which 
include additional tutorial examples and sample reports, an index of 
the commands in LogiCalc, an index of error messages with a short 
explanation of each, and a general index. The appendices will 
hopefully pro^ve to be a handy reference source. 

We at SPI sincerely hope that the LogiCalc program will add a new 
and exciting dimension to the finanacial operations of your 
organization. Our intention is to add to the efficiency and success of 
your organization by making the financial modeling process smooth and 
complete and by providing all the financial information you need with 
a minimal amount of time, money and effort. 



SECTION I OVERVIEW 



I.l Introduction 

LogiCalc is a valuable tool designed to assist you in producing 
professional reports and problem solutions with maximum flexibility, 
creativity and ease. At last, you can put away your paper, pencils and 
erasers and use your computer system to create a multitude of reports. 
The headaches of correcting and editing columns of numbers can now be 
relieved. 

LogiCalc can help you to increase the productivity of your 
organization by taking the fullest advantage of the greater speed, 
efficiency and flexibility of a computer system. 

Some of the possible applications for LogiCalc include: 

balance statements 

cash flow analysis & forecasting 

general ledger 

inventory records 

job cost estimates 

market share analysis & planning 

patient records 

profit projections 

profit statements 

project budgeting and control 

salary records 

sales projections & records 

tax estimation 

With LogiCalc, you will be manipulating data, either text or 
numeric, on a visually oriented display. The numeric data may either 
be constant or be dependent on other data. LogiCalc has facilities for 
editing, formatting, storing, calculating and printing the data that 
you enter into the computer system. 

There's no better way to become familiar with LogiCalc than to 
jump right in and get your feet wet. This manual will strive to lead 
you clearly through each step of operation of LogiCalc so that you 
will have a thorough knowledge of the possibilities available. To 
accomplish this, we will use a simple inventory record for an example. 
There will be plenty of practice for you once each step of operation 
has been demonstrated. 
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1.2 ACCESS 



BEFORE YOU PROCEED ANY FURTHER: PLEASE MAKE SURE THAT 
YOU HAVE MADE A COPY OF YOUR LOGICALC DISK AND HAVE 
STORED THE ORIGINAL IN A SAFE PLACE. 



A pre-installed version of LogiCalc for the Morrow Designs 
Terminal is supplied with your system. If you have a Morrow Designs, 
or other full feature terminal, you will not need to install LogiCalc. 
If you are unsure about whether or not you need to configure LogiCalc 
for your terminal, read Appendix D of this manual, or contact your 
dealer or Morrow Designs' Customer Serive Department. 

We are now ready to introduce the LogiCalc main menu. First of 
all, turn the power on for your machine and insert the SYSTEM 
DISKETTE. 

To enter the program from the Micro Menus, enter option 1. RUN A 
PROGRAM on the MAIN MENU and follow the instructions for entering the 
LogiCalc program. 



To enter LogiCalc from CP/M, enter LC after the CP/M prompt and pr 
the RETURN ([RET]) key: 



ess 



A>lc [RET] 
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1.3 MAIN MENU 



************************************************************ 

* * 

* * 

* Col> A B C D : * 



Row+' 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 



* 
* 

* current : : 

* data : : 
* 

* 

* 



cursor: Al 



current: Al 



type: 

contents : 

edit: 



* Commands :' @ ' , ' ','?', <new data> , <arrows> , <etx> , <TAB> , <CR> '; 'Command * 
*{H)elp R)ecalc F)ormat S)ave L)oad Oopy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat =)loc"k * 

* * 

************************************************************************* 



This is the main menu for LogiCalc and should match the display 
on your screen at this point. 
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1.4 STRUCTURE 

As you can see, LogiCalc is displayed in tabular form with column 
and row headings. Let's see what the advantage is to this format. 

When writing a report you will be working with words and/or 
numbers. These are separate, changeable units of information. Life 
(and report writing) will be much easier if we can work with each of 
these separate units of information independently of the rest of the 
report. Otherwise, if one item in the report changes, you must re-type 
the entire report. With LogiCalc you can refer to, and work with, 
units of information independent of each other. This is done by 
specifying the location of each unit of information through a 
coordinate which is a combination of the column number and the row 
number of the item. A13, G2 7 and P3 are sample coordinate locations. 

To use an analogy, imagine yourself at the post office standing 
in front of a wall of post office boxes. Now imagine that each row is 
identified by a number (1, 2, 3 . . .255 ) and each column is identified by 
a letter (A,B,C. . . Z, AA, AB. . .DV,DW) . Thus, we have 255 rows and 127 
columns of post office boxes. You can locate the address of any post 
office box by referring to its coordinate, e.g. A13, G27, P3. Once you 
locate the post office box, you could store mail inside that box. 

In LogiCalc, memory locations are very similar to post office 
boxes. Once we specify the address of a memory location (its 
coordinate), we can store data inside that memory location. LogiCalc 
has 32,385 such memory locations (255 rows by 127 columns) to allow 
for very long reports . 

As you can imagine, this structure saves you a great deal of time 
by not having to erase columns and columns of numbers when one unit of 
information changes. Instead, you simply change the single unit of 
information and then everything can be automatically recalculated for 
you (these operations will be explained in a later section of this 
manual ) . 
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1.5 TERMINOLOGY 

In order to become more familiar with some of the new terminology 
that you will encounter on the following pages, here is a brief list 
of some of these terms: 



ARRAY 



WINDOW 



ROW 



COLUMN 



Refers to the entire matrix (table) of data. The array 
limits are 127 horizontally and 255 vertically. These are 
only addressing limits. The actual amount of data that can 
be stored depends on the memory size of the computer. 



Because the computer display screen is limited in size, it 
is impossible to view all 32,385 array elements at one time. 
Instead, at any one time, it is positioned onto one 
subsection of the array. This display section is a window 
into a small portion of the array. The window shows 10 rows 
and from 1 to 15 columns. 



Lines of data in the horizontal direction. The rows are 
designated as 1, 2, 3. . .through 255. 



Lines of data in the vertical direction. The columns are 
designated as A, B,C. . .through DW. 



COORDINATE 



ENTRY 



CURSOR 



A position specification in the form 'columnrow'. For 
example, the top left corner of the array is 'Al'. 



A single data item in the array. An entry is located by a 
coordinate. 



The pointer > < at the current data location. (This 

is a different meaning for the word cursor than you may have 

encountered previously. In LogiCalc, the cursor is NOT the 
little box below the display window. ) 
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1.6 FUNCTIONAL OVERVIEW 

For orientation purposes, LogiCalc can be divided into three 
sections and explained according to the function of each of these 
sections . 

A. The upper section is composed of the window into LogiCalc, the 
cursor location indicator and the current location indicator. 

The window allows you to view the report as it stands, including 
all calculated numerical results that have been entered up to 
that point. The window can be moved to view any section of the 
array. 

The cursor location is the present coordinate to which the cursor 
has been moved. When LogiCalc is first accessed, the cursor 
location indicator tells you that the cursor is at location Al . 
The current location indicator tells you where the next entered 
data will be stored. As we shall see, the cursor location and the 
current location can be different. Once the data has been 
entered, the cursor location "jumps" to the current location and 
they are both the same. 

B. The middle section of the main menu is where most of the action 
takes place. 

The two items on the left ('current ::' and 'data ::') never 
change, so you can ignore them from now on. The three lines on 
the r ight, however , are very important. Let's summarize their 
importance: 

1. TYPE 

Indicates whether the information stored at the 'current' 
location is numeric or text (non-numeric). It also indicates 
whether the entry is displayed on the left side of the 
column ( left- justified ) , on the right side of the column 
(right-justif ied) , or centered (center- justified) . If the 
current location is blank, the type line will be blank. If 
an entry has been deleted, the type line will show that 
memory space has been allocated, but is currently empty. 

2. CONTENTS 

Displays what was entered at the 'current' location. If the 
entry was text, the contents will display the text. If the 
entry was a numerical formula, the contents line will 
display the formula (the calculated results of the formula 
may be found in the window at the current location) . So, the 
contents line is a reminder for you to see what was entered 
at the current location. The contents line will be blank if 
the current location is empty. 
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3. EDIT 

Reflects what you are presently typing in. The edit line 
will be blank at any location until you start to type an 
entry. The edit line will show you exactly what you have 
typed until you hit the <return> (or <enter> ) key and then 
what you have typed will move to the contents line and the 
edit line will be blank. The edit line is also used to 
access the functions and commands listed in the lower 
section of the main menu. The line below the edit line is 
used for system prompts and your responses. 

C. The lower section of the main menu displays a list of possible cursor 
movements and operation functions and commands. This section never 
changes and is included mainly as a directory reminder for you to 
choose the operation that you need. 
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SECTION II OPERATIONS 



II.l CALCULATOR FUNCTION 

Before starting with an example application it would be helpful 
to introduce a special calculator function and also the cursor 
movements in order to assist you in learning to find your way around 
in the LogiCalc array. 

The calculator function can be used independently of LogiCalc. 
This saves you from either needing a calculator by your side (or a lot 
of paper and pencils) or from temporarily putting the calculation you 
need into an entry in the LogiCalc array and then having to remove it. 
With the calculator function, anytime you need a quick calculation, 
it's available right away. 

To utilize the calculator, type in your arithmetic expression on 
the edit line and follow the expression by a '?'. (NOTE: use '+* for 
addition, '-' for subtraction, '*' for multiplication,'/' for 
division, '%' for percentages, 'MAX(list)' to find the maximum value 
in the list, and 'MIN(list)' to find the minimum value in the list.) 
For example: 

45 + 89? , 25*5? , 125/9.3? , (18 - 36)*6? , 120%18. 53333? , 

3.14159265359 * 179.4825? 
MAX(E4, F10>F13, H9)? , MIN(A1>L1, B3 , AA1>AA12)? 

(The use of parenthesis is sometimes necessary to insure that the 
sequence of arithmetic operations takes place as you would like it 
to. ) 

The middle example above illustrates a special feature of 
LogiCalc. We have modified the program so that the internal precision 
is accurate to 12 decimal places. The external or displayed accuracy is 
10 places, whether the number includes a decimal point or not. The 
number appearing on the screen will always be accurate to 10 places. 
This is much higher precision than you usually have with a standard 
implementation and allows you to have much more accurate numerical 
values in your reports. 

The last two examples above are called system functions and will 
be discussed thoroughly in a later section of this manual. Briefly, 
the MAX example will find the maximum value in the list composed of 
locations E4, F10 through F13 (all the locations within that range, 
i.e. F10, Fll, F12 and F13), and H9. The MIN example will find the 
minimum in the list of values composed of the range Al through LI 
inclusive, location B3, and the range from AAl through AA12 inclusive. 
These functions can prove to be very useful by saving you from having 
to compute each of the values at the given location and then comparing 
them to come up with the largest or the smallest value. 
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The answer to your expressions will 
below the edit line. 



be displayed on the line 



Later, when you are in the middle of a report, you can even use 
location coordinates in the arithmetic expression and the valiie at 
that location will be used in your calculation. For example, 110%F4? 
will give you the result of taking 110% of the value stored at 
location F4. 

If you enter an expression which evaluates to something divided 
by zero, the system will display ' ?n? ' to let you know that it cannot 
perform such an operation. LogiCalc has its limits I 



II. 2 CURSOR MOVEMENTS 

We can summarize the ways in which to move the cursor with the 
following table (notice that these cursor control keys are the same as 
those used in WordStar): 



ACTION 



RESULT 



CTRL+E ("E) 



CTRL+X ("X) 



CTRL+D ("D) 



CTRL+S ("S) 



CTRL+Z ("Z) 



Moves the cursor to the row directly above its present 
location, unless the cursor is in row 1, in which case 
there would be no movement. 



Moves the cursor to the row directly below its present 
location unless the cursor is in row 255, in which case 
there would be no movement. 



Moves the cursor one column to the right from its 
present location unless the cursor is in column DW, in 
which case there would be no movement. 



Moves the cursor one column to the left from its 
present location unless the cursor is in column A, in 
which case there would be no movement. 



Moves the cursor to the first column of the next row, 
unless the cursor is in row 255, in which case there 
would be no movement. 



Page 9 



RETURN <CR> 



Moves the cursor one column to the right if the edit 
line is blank. If you have typed an entry on the edit 
line, <CR> will enter the data into the 'current' 
location and the cursor will be at the current 
location. Hit <CR> again and the cursor will move one 
column to the right. If the cursor is in column DW then 
hitting <CR> will cause the cursor to move to the first 
column of the next line. 



TAB <TAB> 



Presents the prompt: 



GOTO Al 



below the edit line. You may now enter any coordinate 
on the array and then <CR> and the cursor will move to 
that location. If you would like to jump to the upper 
left corner of the array (Al) you only need to hit <CR> 
and by default the cursor will jump to Al (a very 
useful key) . 

Take a minute or two to experiment with these cursor movements. 
For instance, enter CTRL+D four times. Notice that the window moves 
slightly to include column E and exclude column A. Now hit the <CR> 
key a few times and observe the result. Use the other cursor control 
keys as well. When you feel comfortable with the cursor controls, move 
the cursor back to location Al and continue with the next section of 
the manual . 



I I. 3 EXAMPLE INTRODUCTION 

LogiCalc is designed to be used as a financial report writing 
system. In this section, we will give you a sneak preview of the 
advantages of a computer report writer. We will also introduce the 
example file you will be using to become familiar with LogiCalc. 

To begin, we will load an existing balance sheet file into the 
LogiCalc array and then demonstrate how we can change a data value and 
have the system recompute all the values in the report file (this file 
is also included in Appendix C for reference). After having a sneak 
preview of the capabilities of LogiCalc, we hope you will be 
enthusiastic about the possibilities and will proceed through the rest 
of this manual in order to learn all the operations that are available 
to you in order to produce the best quality reports possible. 

For our initial demonstration, follow the steps outlined below. 
Do not worry about understanding how the operations work as each 
operation will be discussed in detail in the following sections of 
this manual. 
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computer prompt 



your response 



edit 




7 


Command 




L 


filename 




BALSHEET 


load position: 


Al 


<CR> 



explanation 

access command directory 

access Load command 

access balance sheet file 

load file with upper left- 
hand corner at position Al 



The window on the LogiCalc display should now be filled with the 
contents of what resembles a balance sheet. Now, duplicate the 
following steps in order to change an entry on the assets side of the 
report and, of course, an entry on the "liabilities & equity" side of 
the report . 



computer prompt 

edit 
Goto 

edit 
edit 
Goto 

edit 



your response 



explanation 



<TAB> 




access Goto operation 


B7 




move cursor to location 
B7 


5225850. 


35 


enter new data at B7 


<TAB> 




access Goto operation 


B24 




move cursor to location 
B24 


9850.35 




enter new data at B24 



We have substituted two new values into our balance sheet report. 
The totals for both sides are now clearly erroneous. Instead of 
recomputing all the new totals by hand or by calculator, we may 
execute the following steps to recompute all the new totals 
automatically. 
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computer prompt 



your response 



explanation 



edit 
Command 

Recalculate - A) 11 or 
E)ntry 



R 



access command directory 
access Recalculate command 



recompute all values in the 

balance sheet file 



As you can see, once the above steps are executed, all the totals 
are recalculated to reflect our changes in the data in the balance 
sheet. 

Even though LogiCalc is mainly a financial report writing system, 
we have chosen to use an inventory control report as our example file 
in this manual. One of our reasons for choosing an inventory report 
lies in the simplicity of the entries involved in the report. By using 
an inventory example, no one will be confused with this manual because 
of their lack of familiarity with financial reports. Everyone can feel 
at home with an inventory report which basically counts the number of 
parts you have on hand, how many parts you usually stock, and the 
resultant number of parts you wish to order. So, we felt that an 
inventory report would be universally applicable to all and therefore 
lend to the clarity and usefulness of this manual. 

A second reason for choosing an inventory report is to 
demonstrate the wide range of applications available with LogiCalc. 
The LogiCalc program may be used for virtually any type of report, not 
just for financial reports. 

In our example, we will enter a report that lists eight different 
sizes of bolts and keep track of and manipulate some related 
information. 

We do not need to be concerned with entering a title for our 
report at the very beginning. When we explain the PRINT operation, you 
will see that we can add a title before the report is printed out. 



I I. 4 TEXT DATA ENTRY AND THE TEXT EDITOR COMMAND 

Before we can begin with our inventory example, we must clear the 
screen of our balance sheet file. Follow the steps below to clear the 
screen. Remember, the operations will be demonstrated later, so don't 
worry if you do not understand the steps at this time. 
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computer prompt 



your response 



explanation 



edit 
command 

Delete: A) 11 R)ow 
C)olumn E)ntry 

Verify Y/N 



D 

A 
Y 



access command directory 
access Delete command 

delete entire screen 

insures deletion is ok with you 



Is the cursor at Al? Good I Notice that the type, contents and 
edit lines are all blank. Now, type in 'PART #' and then hit the <CR> 
key. The following happens: 

1. Since the first character was a 'P', the entry was interpreted as 
text. 

2. Since the entry was interpreted as text, the entry was 
automatically left-justified (at the left side of the column). 

3. When you hit <CR>, the entry on the edit line moved to the 
contents line and 'PART #' also appeared at Al in the window 
while the edit line went blank. 

Now, instead of being blank, the middle section of the main menu will 
show the following: 



type: text: left justified 
contents : ' PART # ' 
edit: 



Since 'PART # ' is a text entry, the screen is correct and agrees 

with our intention. However, instead of having the entry left 

justified, we would like it to be right justified because there will 

be a column of numbers underneath 'PART #' and numbers are usually 

right justified. If the numbers are underneath the text it will help 
our report to look much nicer. 

In order to change the entry from left justified to right 
justified, enter '/R' on the edit line with the cursor at location Al. 
Our entry now moves over to the right side of the column. Similarly, 
if you wish to center justify an entry, enter '/c' at the location you 
would like centered and if you wish to left justify an entry, enter 
'/I' at the entry location. 
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If you make a mistake in typing and catch it before you hit <CR> 
you may hit the <backspace> key to erase one character at a time or 
you may use the Text Editor command as described below. If you notice 
the mistake after hitting RETURN, the Text Editor command will be 
especially useful by allowing you to correct the mistake without 
having to type in the entire entry over. 

It will be a good idea to take a minute or two now to describe 
the procedure for using the Text Editor command. This will introduce 
you to a command which will allow you to easily correct any mistakes 
in typing. 

As an example, with the cursor still at location Al, type 'PR 
TS3 ' , but do not type <CR> to enter what you have typed. Obviously, 
someone needs to practice their typing, right? We would like 'PART #' 
to be stored at this location, so we will have to make some changes. 
There are two ways in which we could change this entry. One way would 
be to backspace over all the characters you have typed and then type 
the entry over again. The alternative would be to use the Text Editor 
command (or Text for short) . With this short entry, it is up in the 
air as to which alternative would be easier to use. However, later on 
when you will be entering complex formulas. Text may prove to be much 
easier to use to make a simple change. We will use Text in this 
example in order to demonstrate its capabilities. 

Once you have typed in 'PR TS3' and pressed <CR> , follow the 
steps outlined below to execute the Text Editor command: 

computer prompt your response explanation 



edit ; access command directory 

Command T access Text Editor command 

Now the line below the edit line will appear as shown in the 
illustration below. 



Text: <up>,<etx> inserts; <down> deletes; <esc> closes; <cr> exits 



Do not be alarmed if this line looks awesome. The commands for 

Text are very easy to learn and use. This shorthand will serve as 

reminder of the command options . These options are summarized in the 
following table: 
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S <left> 



D <right> 



Z <ETX> <up> 



X <down> 



SPACE BAR 



<CR> 



Text Editor Cursor Control Keys 



CTRL+S moves the type positioner one character to the 
left without erasing any characters - this works like 
the <backspace> key. 



CTRL+D moves the type positioner one character to the 
right without erasing any characters. 



CTRL+z inserts as many spaces as possible from the type 
positioner location to the end of the line without 
easing any previously typed characters. 



CTRL+X deletes the character currently at the type 
positioner location, leaving no blank space. 



The SPACE BAR deletes the character at the type 
positioner, leaving a blank space. 



Exits the Text Editor command. Note that another <CR> 
must be typed in order to enter the newly edited text 
into the LogiCalc array. 



Since we have now introduced these 
demonstrate how they may be used. 



options we may proceed to 



First of all, move the type positioner to the right three or four 
spaces by entering *D and then back to the left by typing the ^S. As 
you can see, no characters are erased and you are free to move the 
type positioner to the location at which you would like to begin 
editing the text. 

The easiest way to edit this line is to move the cursor to the 
second letter (R) and re-enter the word correctly. Now our text will 
read 'PART #', as it should. 

Before we let you loose to continue to the next command, we 
should try out the other two Text options. Move the type positioner to 
the 'P* and then type ^Z. The result will be an insertion of 29 
characters before the text 'PART #'. The "line insert" option inserts 
as many blank spaces as it can after the type positioner while still 
preserving any characters which have been already typed. The reason 29 
spaces are inserted in this case is because there is a maximum of 35 
charactes for a text entry and 3 5 minus six for the existing 
characters leaves room for an insertion of 29 blank spaces. The 
function of this option is to allow you to enter in characters without 
having to retype the existing text. 
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For example, with our 'PART #' text, we could now enter 'BOLT' 
then enter ^X 2 5 times to "close" the insertion back up. This would 
result in the text 'BOLT PART #'. For now, we will leave the 'BOLT* 
out, so if you have typed it in you may use ^X to delete the 
characters. 

So, the ^Z option allows you to insert text anywhere within the 
existing text and "X may be used to close the insertion back up. 

If you wish, you may practice a little more with the Text 
options. When you are ready, type <CR> to exit Text and control will 
be returned to the edit line. Once control is back to the edit line, 
you may hit <CR> again to enter the text into the LogiCalc array. Now, 
don't forget to type '/R' to change the entry to right justification. 

The Text Editor should prove to be very handy by allowing you to 
make changes to an entry without having to retype the entire entry. 
Not only may you use Text for new entries, but you may also use it for 
any existing entry you would like to edit. All you need to do is to 
move the cursor to the location of the entry you would like to edit 
and then type ';T' to access the Text Editor command. You will be able 
to edit the text of the existing entry as if it were a new entry. The 
Text Editor command is especially handy for editing formulas which are 
not so easy to type and offer a greater potential for mistakes. 

We have now finished our discussion of the Text Editor command 
and are ready to proceed onwards. 

Move the cursor to location Bl. Since we will want all our column 
labels to be uniform, they should all be right justified. There is an 
easier way than entering each label and then changing the 
justification. This time, type in ' /RPART NAME' on the edit line and 
then hit <CR> . As you can see, the entry is automatically right 
justified. 



II. 5 FORMAT (COLUMN WIDTH) COMMAND 

Since there is very little space between the two column labels, 
it would be useful if there were some way to make the columns wider 
(or narrower if needed). Report writing could become much more tedious 
and time consuming if there was no way to specify individual column 
width, so we have made the extra effort to give you this flexibility. 
You are allowed up to 35 characters for a text entry, so there will be 
some situations in which we must widen the column. With Logicalc you 
can specify columns to be anywhere from 3 to 63 characters wide! Here 
are the steps for widening a column: 
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computer prompt 



your response 



explanation 



edit ; 

Command F 

P)recision(2) or W)idth(10) 

or Form Mode (clear) W 



Column B width ( 3 ... 63 ) 



15 



access command directory 
access Format command 

to alter column width 
widen column to 15 spaces 



This will result in our column being widened from the standard 
width of 10 spaces to the width of 15 spaces that we chose. One point 
to remember is when you widen the location Bl, it also widens 
locations B2 through B255 simultaneously. That is, when you widen one 
location you are widening the entire column. 

(NOTE: If you find that you have accidentally accessed a command 
operation that you really do not need, you may abort that operation in 
one of two ways: If the system is waiting for one keystroke only, 
enter <esc> to return control to the edit line. If the system is 
waiting for an entry and then a <CR>, we need only hit <CR> without 
typing anything else.) 

Let's move on to location CI. This time, let's change the column 
width first. This will save us some trouble if we try to enter an 
entry that is too long for the column. 

Here is a summary of actions for column C: 



computer prompt 



your response 



explanation 



edit ; 

Command F 

P)recision(2) or W)idth(10) 
or Form Mode (clear) W 

Column C width(3. . .63 ) 15 

edit /RSUPPLIER # 



access command directory 
access Format command 

to alter column width 
widen column to 15 spaces 

enter data for CI with 

right justification 



The rest of the column headings will be very similar to what we 
have demonstrated. So now, you can have an opportunity to practice 
entering text data. Below is a summary of data that you may enter for 
columns D through L. If you get stuck, return to the outline of steps 
for column C and review the procedure . 
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Column D - format the column to a width of 18 and then enter 

'/RSUpplier name* 

Column E - format the column to a width of 11 and then enter 

•/RPRICE' 
Column F - format the column to a width of 11 and then enter 

• /RCOST ' 
Column G - format the column to a width of 18 and then enter 

•/RPROFIT/UNIT' 
Column H - format the column to a width of 12 and then enter 

•/R%profit' 
Column I - format the column to a width of 24 and then enter 

•/RQUantity stocked' 

Column J - format the column to a width of 24 and then enter 

•/RQUANTITY ON HAND* 
Column K - format the column to a width of 24 and then enter 

'/RQUANTITY ORDERED' 
Column L ~ format the column to a width of 18 and then enter 

'/rcost/order' 

By this time you probably feel like an expert at widening columns 
and entering right justified text, right? 

Now hit the <TAB> key. 

To the prompt 

GOTO Al 

enter <CR> . With the cursor at location Al, your screen should be 
similar to the following: 
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* * 

* * 

* Col> A B C D : * 

* X}r\r.T4 ^ * 



Row+- 

1 
2 

3 
4 
5 
6 
7 
8 
9 
10 



PART #< 



PART NAME 



SUPPLIER # 



SUPPLIER NAME 



* 
* 

* current : : 

* data : : 
* 

* 

* 



cursor: Al 



current: Al 

type: text: right justified 
contents: PART # 
edit: 



*Coinmands : • @ • , '^•,'?',<new data> , <arrows> , <ETX>, <TAB> , <CR> , ' ; commands:* 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)liat =)lock U)disk}* 
* * 



II. 6 THE GOTO COMMAND 

Now scroll to the right to examine the rest of your column 
labels. At location LI, if everything is correct, duplicate the 
following steps: 



computer prompt 



your response 



explanation 



edit 
Command 
GOTO Al 



G 
A2 



access command directory 
access Goto command 
move cursor to A2 



As with the <TAB> key, if you would like to goto Al, you need 
only press <CR> . By default, the cursor will jump to Al . However, if 
you would like to "goto" some other location than Al, simply enter the 
coordinate and the default will be overridden. The cursor will jump to 
the location you entered. 
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From the preceeding example, we can see that the Goto command is 
identical to the <TAB> key. The Goto function is so useful that, in 
case a machine doesn't have a <TAB> key, you can still use the Goto 
command (but if your machine does have a <TAB> key it's usually easier 
to use). From now on in this manual, we shall say 'Goto <coordinate> ' 
and let you choose which action to take to get there. 



II. 7 REPETITION FUNCTION 

In order to make our report orderly and attractive, it would be 
nice to underline the column labels. However, it would be bothersome 
to hit the underline mark enough times to underline 12 columns. 

There is a much easier way to accomplish our goal. What we shall 
do is underline one column and then copy that underlined column into 
the next 11 columns. It's even easier than it sounds 1 

First of all, we want to fill location A2 with dashes and this 
will give the effect of underlining Al . You can do this in one of two 
ways. Either we can enter in as many dashes as the field is wide or we 
can use the repetition function. For reasons which will be obvious in 
a minute, let's use the repetition function. 

With the cursor at A2, enter '/=-'<CR>. Once we hit <CR> the 
location A2 is filled with dashes. The repetition function takes 
whatever string of characters is following the repetition symbol (/=) 
and repeats it for the entire width of the column, no matter how wide 
the column is (for an example of a repeated string of more than one 
character, please refer to APPENDIX C - example #3 - step #15). 



I I. 8 THE COPY COMMAND 

Now that we have dashes in one location (A2), we would like to 
copy them into locations B2 through L2. Here is a summary of how we 
can use the Copy command to accomplish this in one operation. 



computer prompt 

edit 

Command 

from coord (> coord) 

to coord (> coord) 



your response 

C 

A2 
B2>L2 



explanation 

access command directory 
access Copy command 
copy value at A2 
copy into B2 through L2 



Now, there should be dashes throughout row 2 from column A to 
column L. 
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(NOTE: if we would have entered 10 dashes at A2 - the field was 10 
spaces wide - instead of performing the repetition function when we 
copied A2 into B2 through L2, we would have had 10 dashes in each 
column. The result would have been less attractive since the columns 
are all of different widths. What we did was to copy the repetition 
function to fill the entire width of the column with the specified 
characters from column to column. The result was dashes throughout 
each column - no matter what its width 1 ) 

In general, there are four choices with the copy function. You 
may copy: 

1 . from an entry to an entry 

2. from an entry to a range of entries 

3. from a range of entries to a range of entries 

4. from a range of entries to an entry 

(#4 above is actually a shorthand way of copying from a range into a 
range. The system will count how many entries are in the range you are 
copying from and copy that range into another range, starting from the 
single entry that you specify. For example, if you say copy A2>C2 into 
A3, the system will actually copy A2>C2 into A3>C3. So, there are 
really only three choices with the Copy command.) 

There is one other point that should be brought out regarding the 
Copy command. If you are copying numerical values or a formula into a 
range of coordinates, then before copying, the prompt will ask: 

R)elative, P)rompted or N)o adjustment 

If the value you are copying will stay constant throughout the 
range of entries you are copying into, then enter 'N' . If the value is 
a formula and will change as it is copied from one location into 
another, then enter 'R* so the formula will be copied and will adjust 
all the coordinates automatically for you so the formula will be 
relative to the new location. 

If the formula is to be copied Relatively for some of the entries 
in the range and with No Adjustment for other entries in the range, 
then type 'P' for Prompted. If you select Prompted, you will be 
prompted to select Relative or No Adjustment for each of the 
coordinates in the formula at each entry in the range of entries you 
are copying the formula(s) to. This will give you maximum flexibility 
in that you may use the Copy command no matter what combination of 
Relative or Absolute copying you would like to perform. Examples of 
these operations will be given in this manual. 



I I. 9 NUMERICAL DATA ENTRY 

A numerical expression may be enterd into any location in the 
LogiCalc array. (Remember: an expression may be constant or variable.) 
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The terms of the expression may be a: 

1 . number 

2. coordinate reference - in which case the coordinate 
is replaced by the value stored at that coordinate 

3. system function - an arithmetic operation which the 
system already knows how to do without explicit 
directions. You must specify which function and on 
what argument list (list of values) the function 

is to operate. 

The available system functions for LogiCalc are: 

SUM = summation of values in argument list 
CNT = number of items in list that are 

numerically valued 
AVG = mean value (i.e. SUM/CNT) 
MAX = the maximum value in the list 
MIN = the minimum value in the list 

The values that are contained within the argument list of a 
system function may be any of the following: 

1. reference coordinate (e.g. F4) 

2. range of reference coordinates (e.g. F4>F10) 

3. other expressions enclosed in parentheses 

With this in mind, it's obvious that there are a very large 
number of possible ways to manipulate numerical data with a minimum 
amount of complexity and work. As we proceed, we shall demonstrate 
some simple applications of many of these possibilities. 

We have tried to design LogiCalc to be as convenient to use as 
possible. For this reason the system will display the symbol ' ?n? ' 
whenever it encounters a numerical expression which evaluates to 
something divided by zero. This informs you right away of the problem 
and you may then seek out the solution. If you try to copy such an 
entry, all the entries you copy into will also show the ' ?n? ' symbol. 
You may add or subtract values from this entry and the system will 
simply ignore the undefined expression. However, if you try to 
multiply or divide this entry by another value the result will be 
undefined and ' ?n? ' will be displayed in the destination location 
after the recalculate command has been executed. You will also see the 
' ?n? ' symbol if you try to multiply or divide a value by a cordinate 
which does not have a numerical entry. 

In our inventory example, we have eight different sizes of bolts. 
The part #s on these bolts range from 12345 to 12352 in sequence. Once 
again, we have two ways in which we could enter this data. We could 
enter each number individually or we could enter one number and then 
use a simple formula and then copy that formula into the rest of the 
locations to result in the right values. 



Page 22 



To start, goto A4. Enter '12 345' on the edit line. After you hit 
<CR>, you will notice that the value at the location A4 reads 
'12345.00*. This is because the system automatically assigns two 
decimal places to a numeric entry. Since we are handling part numbers 
(which don't need decimal places), it would be helpful if we could 
change the number of decimal places to 0. 



11.10 THE FORMAT (PRECISION) COMMAND 

With the Format command there is a way to specify from to 10 
decimal places. The steps to set the decimal precision at are as 
follows: 



computer prompt 



your response 



explanation 



edit ; 

Command F 

P)recision(2) or W)idth(10) 

or Form Mode (off) P 



Column A precision ( 0. . .10) 







access command directory 
access Format command 

alter decimal precision 
change decimal precision to 



Now, the value at location A4 should read '12345' - our desired 
number . 

(NOTE: LogiCalc allows you to have a decimal precision of to 10 
places. You may find your numbers being converted to exponential form 
if the column width is not large enough, i.e: 

LogiCalc also allows you the possibility of specifying the 
decimal precision for any individual entry. This means you may have 
values of different decimal precision even within the same column! One 
entry may be accurate to 9 places and the value directly below it 
accurate to 1 place. The steps to setting an individual decimal 
precision entry are very similar to the steps for setting the decimal 
precision for a whole column with one exception as illustrated below: 



computer prompt 



your response 



explanation 



edit ; 

Command F 

P)recision(2) or W)idth(10) 

or Form Mode (off) P 



Column A precision(0. . .10) 



E0 



access command directory 
access Format command 

alter decimal precision 

change decimal precision to 
only at cursor location 
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To set the decimal precision for an individual entry you must 
enter 'E' before the number of decimal places. The above steps would 
change the decimal precision only at the cursor location and not at 
any other location in the array. It should be noted that the decimal 
precision for an individual entry can only be set after a value has 
been entered for that location. 

The next step is to determine a formula for calculating what the 
next part # will be. In this case, since the part #s are in sequence, 
each part # is determined by adding 1 to the previous part #. So, at 
location A5, enter '1 + A4 ' . The middle section of the main menu will 
show: 



type: numeric 
contents : 1 + A4 
edit: 



This tells you: 

1. when you entered 1, the entry was interpreted 
as numeric 

2. the contents are equal to 1 plus the value 
stored at A4 

3. the numeric value is automatically right 
justified 

Notice that in the window at location A5, the value reads 12346. 

The main purpose in entering this formula was to be able to copy 
it into the remaining locations in order to avoid having to enter each 
part # individually. So, follow these steps to enter the rest of the 
part #s: 



computer prompt 



your response 



explanation 



edit 

Command 

from coord (> coord) 

to coord (> coord) 



C 

A5 
A6>A11 



R)elative or N)o adjustment R 



access command directory 
access Copy command 
copy value at A5 
copy into A6>A11 

value will change from 

entry to entry 



Note, this time we chose 'R' for relative adjustment. If we would 
have chosen 'N' for no adjustment, the result would have been the 
value 12346 in locations A6 through All because the formula for each 
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location would have been '1 + A4 ' . But, since 'R* was selected, each 
value was obtained by adding 1 to the preceeding value (i.e. the 
formula for A6 became 1 + A5,etc.). 

Now, your screen should match the following replication: 



■k-k*1c1c*4e * * ************************************************************ 

* 
* 

* Col> A B C D : 

* 



Row+- 



3 
4 
5 
6 
7 
8 
9 
10 



PART # 



PART NAME 



SUPPLIER # 



SUPPLIER NAME 



12345 

12346< 

12347 

12348 

12349 

12350 

12351 



cursor: A5 



current : A5 

type: numeric 
contents : 1 + A4 
edit: 



* 
* 

* current : : 

* data : : 
* 

* 

* 

♦Commands :'@', '^','?', <new data> , <arrows> , <ETX> , <TAB> , <CR> , ' ; command 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat =)lock 
* 

********************************************************************* 



**** 
* 
* 
* 

* 

* 
* 
* 
* 
* 
* 
* 
* 
* 
* 

* 

* 
* 
* 
* 
* 
* 
* 

s : * 

ed}* 

* 

* 

**** 



11.11 THE 



FUNCTION 



Move the cursor to location B4. We now want to enter the part 
names for our bolts, which range in size from 1/4 inch to 1 1/2 inch. 
Part name should be a text entry, but if we enter '1/4" BOLT', the 
following error message will result 

Error 7-> 1/4?" BOLT hit space [B4] 

When you hit the <space> bar the value at B4 becomes ?n?. To avoid 
this error, you must let the system know that even though the entry 
begins with a number, it should be stored as a text entry. To change 
the text type of an entry, type in '1/4" BOLT', BUT BEFORE you hit 
<CR>, hit the '^' key. This will switch the text type from numeric to 
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text (in this case). So, the ' " ' key allows you to toggle the text 
type back and forth to fit your data entry. 

Once <CR> is entered after '1/4" BOLT"^', the entry will be left 
justified. Now enter '/R' to switch the entry to the right side of the 
column. 

This example was to illustrate the use of the '^' key in allowing 
you the flexibility to enter numbers into text entries and text into 
numeric entries. 

In our inventory example, we can accomplish this same action in 
another way. Move the cursor to B5 and enter '/R3/8" BOLT'. The system 
will automatically interpret the '/' as text, since only text can have 
its position switched (remember that numbers must be right justified). 

You may now finish entering the bolt names in locations B6 
through Bll with the following data; 

at B6 /Rl/2" BOLT 

B7 /R5/8" BOLT 

B8 /R3/4" BOLT 

B9 /R7/8" BOLT 

B10 /Rl" BOLT 

Bll /Rl 1/2" BOLT 

Now it's time for some practice. Try at least once before looking 
at the answers. The data is as follows: 

1. The 1/4", 3/8" and 1/2" bolts are made by ACME (supplier name, 
column D) whose supplier # is 35 (column C) 

2. The rest of the bolts are supplied by UNIVERSAL whose supplier # 
is 83. 

(HINT: use the Copy command to make your work a lot easier and 
remember to right justify your answers and set your decimal 
precision to the appropriate value.) 
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Now, compare your screen to the following replication: 



PART # 



PART NAME SUPPLIER # 



SUPPLIER NAME 



**************************************************************** 

* * 

* * 

* Col> A B C D : * 

* 
* 
* 
* 
* 
* 
* 
* 
* 
* 



Row+- 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 



12345 
12346 
12347 
12348 
12349 
12350 
12351 



1/4" BOLT 

3/8" BOLT 

1/2" BOLT 

5/8" BOLT 

3/4" BOLT 

7/8" BOLT 

1" BOLT 



35 
35 
35 
83 
83 
83 
83 



ACME 
ACME 
ACME 
UNIVERSAL < 
UNIVERSAL 
UNIVERSAL 
UNIVERSAL 



cursor: D7 



current: D7 



current: : 
data : : 



type: text: right justified 
contents: 'UNIVERSAL' 
edit: 



♦Commands : ' @ ' , '"','?', <new data> , <arrows> , <ETX>, <TAB> , <CR> , ' ;commands : * 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto Dnsert P)rint E)dge 0)rder ?)storage W)hat =)lock * 
* * 

************************************************************************* 

If this agrees with what you have on your screen, then give 
yourself a pat on the back. If not, find the place Where the 
difference occurs. If it's in the columns for supplier # or supplier 
name, then check the steps below. If it's somewhere else on the 
screen, then refer to the section of this manual (II. 9 - 11.11) in 
which that operation was demonstrated to try and locate the error. 

If you had trouble with copying the information for supplier 
number and name, follow through these steps: 



1. Goto C4 
computer prompt 



your response 



explanation 



edit ; 

Command F 

P)recision(2) or W)idth(10) 

or Form Mode (clear) P 



access command directory 
access Format command 

alter decimal precision 
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Column C precision 


(0., 


..10) 





edit 






35 


edit 






* 


Command 






C 


from coord (> coord ) 






C4 


to coord (> coord) 






C5>C6 



set precision at places 

enter data at C4 

access command directory 

access Copy command 

copy value at C4 

copy value into C5 through C6 



2. Goto C7 
computer prompt 

edit 

edit 

Command 

from coord ( > coord ) 

to coord (> coord) 



your response 
83 

7 

C 

C7 

C8>C11 



explanation 

enter data at C7 

access command directory 

access Copy command 

copy value at C7 

copy value into C8 through CI] 



3 . Goto D4 
computer prompt 

edit 

edit 

Command 

from coord (> coord) 

to coord ( >coord) 



your response 
/RACME 

i 

c 

D4 
D5>D6 



explanation 

enter data at D4 
access command directory 
access Copy command 
copy value at D4 

copy value into D5 through DC 
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4. Goto D7 
computer prompt 



your response 



edit 




/RUNIVERSAL 


edit 




• 


Command 




C 


from coord ( > coord ) 


D7 


to coord ( 


> coord ) 


D8>D11 



explanation 

enter data at D7 

access command directory 

access Copy command 

copy value at D7 

copy value into D8 through Dll 



11.12 THE SAVE COMMAND 

When writing a nice, beautiful report it's a wise idea to 
occasionally save what you have written, so that there is no chance of 
it being destroyed. If, for instance, you accidentally hit the <break> 
key or someone accidentally unplugged your machine, then all your work 
would be gone and you can guess how that feels. 

Now seems to be a good time to save what we have so far produced. 
Saving a file or a subsection of a file is fairly simple. Just follow 
these steps: 



computer prompt 

edit 
Command > 
filename 



your response 



Password ( <CR> = none) 
P(artial or A(ll 



explanation 

access command directory 

access Save command 

choose a filename for 
your file to be saved under. 
Filename must be 10 
characters or less . 

{ <CR> or <password> } * see below * 

A save the entire report 



EXAMPLE 



1. If you don't need your file saved under a secret password, enter 
<CR>. After entering <CR>, the prompt will tell you that your 
file has been saved and then control will transfer to the edit 
line. 
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2. If you do want your file protected by a password, enter your 
choice (either one that you can remember easily or that you have 
written down in a safe place). Remember, the password must be 
re-entered exactly as you first entered it. 

After you enter the password, the system will prompt 



Again: 

Enter the password again to verify that you have it right. If you 
enter a different password the second time, the save command will 
be aborted and control will return to the edit line. 

If you enter the same password twice, the file will be saved 
under the filename you specified and the file will be protected 
against being destroyed or changed because of the password 
protection. 

If you get an error message, then you probably do not have enough 
room on your disk for the file to be saved. If this is the case 
you may use CP/M STAT command to check and see how much room you 
do have. If you need more room you may use the Virtual drive 
feature to copy your file onto another disk or the CP/M ERA 
command remove old LogiCalc reports to make more room. 

Now that we've saved 'EXAMPLE', let's return to the Save command 
and illustrate one other point. 



computer prompt 



your response 



explanation 



edit 

Command 

f i 1 ename : EXAMPLE 



S 
<CR> 



access command directory 
access Save command 
access our saved file 



file exists, do you want 
to destroy old contents 
(Y/N?) 



see below 



1. If you enter 'N' , the system will abort the Save command and 
control will be returned to the edit line. This is to avoid 
accidentally writing a new file over an already existing file of 
the same name . 

2. If you enter 'Y' , and there is no password protecting the file, 
then the system will prompt 

Password(<CR> = none): 

After this prompt is answered (which is asking if you want the 
new contents of the file to be password protected) the system 
will ask if you would like to save only a portion of the array or 
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all of the array. 

If you only need to save a portion of the array (or would like to 
store part of the array under another name so you may access 
either the entire report or a subsection of the report) the 
system will ask you for the upper left corner of the portion you 
would like to save and then will ask for the bottom right corner 
of the subsection you would like to save. 

If you would like Al to be the upper left hand corner you may 
type <CR> . Otherwise enter the appropriate location or move the 
cursor to the location and type ' @ ' . 

If you would like the bottom right corner to be the cursor 
location, you may hit the <CR> key. Otherwise, enter in the 
location you would like for the bottom right corner. 

Once you have entered the coordinates of the subsection of the 

report you would like to save or you entered 'A' to save the 

entire report, the system will write the present contents of the 
LogiCalc array into the file over the previous contents. 

3. If you enter 'Y' , and there is a password protecting the file, 
the system will prompt 

Verify password to remove: 

Now, there are two possibilties : 

1. If you enter the wrong password, the Save operation will be 

aborted and control will be returned to the edit line (this 
demonstrates that your file is protected by the password). 

2. If you enter the correct password, the system will prompt: 

Password(<CR> = none): 

This means the old contents have been removed and the system 
is asking you if you would like to protect the new contents 
of the file with a password. When the new password prompt 
has been answered, the system will ask you if you would like 
to save a portion of the report or the the entire report - 

If you would like to save only a portion of the report, 
enter 'P' and the top left and bottom right coordinates of 
the portion you would like to save. 

You may use the defaults shown in the prompts or enter in 
the values you would like. Enter 'A* if you would like to 
save the entire report. Once you have answered this prompt, 
the system will acknowledge that the file has been saved and 
control will transfer to the edit line. 
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One of the friendly features of the Save command is that the 
filename is displayed under the bottom left corner of the LogiCalc 
array after the filename under which you would like the file to be 
saved has been established. This serves as a little reminder. 

Saving a partial file can be very useful in conjunction with the 
Merge command (discussed in section 11.21). 



11.13 ?) STORAGE COMMAND 

Before we continue, let's check to see how much storage space we 
still have available for our report. This will give you an idea 
regarding how long your report can be . 

To execute the ? Storage command, enter ';' and then enter '?'. 
The system will respond below the edit line with the answer 

room for more entries 

Numbers will be filled in for the blanks informing you of the 
approximate number of entries that you can still make. 

In our example, there should still be room for about 650 entries. 

Please, make sure to distinguish between the ';?' command (to 
check storage space) and the *?' function (your built-in calculator 
function) . 

If you have been entering a long report and the message "Memory 
Getting Low" appears below the right side of the window, you should 
not try to enter anything more. Theoretically you could, but when you 
went to save the file or print the file, you would run the risk of 
losing something at the end of your report. So, better to avoid the 
danger before it arises. 

If you continue entering information after the "Memory Getting 
Low" message and the message "Out of Memory" appears, then nothing 
more can be entered and the chances are very high that you will lose 
something from the end of your file when you try to save or print the 
file . ) 

Now, we can enter the data for the price and the cost of the 
bolts and then calculate the profit/unit and the % profit values. 

The price of the 1/4" bolt is $.02 and each of the bolts after 
that is 40% higher than the previous bolt. Again, we can enter the 
data for the first entry, then find a formula for the successive 
entries and copy that formula from location to location. 

Move the cursor to location E4. At E4, you can enter the value 
'.02'. Since the next value is 50% higher than the preceeding value. 
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we can enter the formula '150%E4' at E5. The result in the window at 
E5 should be .03. 

(NOTE: another advantage to writing a formula is, in the event of a 
price change, you only have to change the initial value and then the 
prices for the rest of the bolts can be automatically re-calculated 
(this operation will be demonstrated in a later section of this 
manual . ) 

Once you have entered the formula at E5, you can copy the formula 
with relative adjustments into the locations E6 through Ell. By 
copying with relative changes you will insure that the system will 
automatically adjust the coordinates within the formula to accurately 
reflect the correct coordinates. As an example, the formula at 
location E6 will say 150%E5 (not the original formula of 150%E4). The 
steps are: 



computer prompt 



your response 



explanation 



edit 



Conmiand 



from coord (> coord) 



E5 



to coord (> coord) E6>E11 

R)elative or N)o adjustment R 



access command directory 
access Copy command 
copy value at E5 
copy into E6 through Ell 

value will change from 

entry to entry 



For simplicity, let's say the cost of the bolts follows the same 
pattern as the price of the bolts, each one is 50% higher than the 
previous one. The cost for the 1/4" bolt is $.015. You may have 
noticed three decimal places for the cost of the 1/4" bolt. As a 
result, you will need to change the decimal precision for column F to 
three places. Try it on your own. If you have some trouble, here are 
the steps : 
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computer prompt 



your response 



explanation 



edit 
Command 

P)recision(2) or W)idth(10) 
or Form Mode (clear) 

Column F precision ( 0. . .10) 



access command directory 
access Format command 

alter decimal precision 

change precision from 2 to 
decimal places 



Now enter '.015' at F4 and then enter the formula at F5 to show 
that the next bolt is 50% higher than the previous bolt. Following 
this, copy the formula into locations F6 through Fll with relative 
adjustments . 



11.14 THE EDGE COMMAND 

At the same time we are checking our entries for the prices and 
costs of our inventory of bolts we can also demonstrate the use of the 
Edge command. The Edge command locates the cursor and moves the cursor 
location (the coordinate where the cursor presently is) to the upper 
left hand corner of the display window and then displays the next 10 
rows down from the cursor location and however many columns to the 
right of the cursor location that the screen will fit. This command 
will be useful in many instances in which you would like to isolate a 
specific section of data on the display screen. 

To execute the Edge command, the first action you should take is 
to move the cursor to the location that you would like to be the upper 
left hand corner of the window. We would like to isolate the price and 
cost values, so move the cursor to location E4. Now, enter ' ; ' and 
then enter 'E'. Within the window should be two columns of numbers 
resembling the following illustration 
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************************************************************** 

* 

* 

* Col> E F G H : 

* 



Row+- 

4 

5 

6 

7 

8 

9 
10 
11 
12 
13 



0.02< 

0.03 

0.04 

0.06 

0.10 

0.15 

0.22 

0.34 



0.015 
0.022 
0.033 
0.050 
0.075 
0.113 
0.170 
0.256 



cursor: E4 



current: : 
data : : 



current: E4 

type: numeric 
contents: .02 
edit: 



* 
* 
* 
* 
* 
* 
* 

♦Commands: '@', '^'#'?'# <new data>, <arrows>, <ETX>, <TAB>, <CR>, * ; commands: 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat =)lock 
* 

*********************************************************************** 



Got it? Very goodi If not, take a minute to review the price 
column again and compare it to your own work. The cost column follows 
the same procedure, only the decimal precision is set to three places. 



Our next task is to calculate the value 
each bolt sold. As can be expected, we can write 
the formula from location to location. Since the 
set to three places in column F for cost entries 
to set the decimal precision to three places fo 
calculations for profit involve the cost entries 
decimal precision to three places for column G. 
of steps covered for changing the decimal precis 
need a reminder. 



for the profit made on 
a formula and copy 
decimal precision was 
, it will be necessary 
r column G because the 
. Go ahead and set the 
Refer to the outline 
ion in column F if you 



11.15 



THE @ FUNCTION 



The @ function is a very useful aid in entering data. This 
operation will allow you to move the cursor around the screen and when 
you have located the entry you would like to use, execute the (§ 
function to enter the cursor location into the current location. 
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There are several ways to enter the formula for profit (i.e. 
price - cost) into location G4. Here are two of the possibilities (the 
second alternative utilizes the @ function): 

1. At location G4, enter ' +E4 - F4 ' . The '+' sign in front of the 

'E' is optional, but it is an easy way to insure that 'E4' is 
interpreted as a numeric entry rather then a text entry. If you 
don't use the '+' , make sure to use the ' " ' to change the entry 
type from text to numeric . 

2. At location G4, enter a '+' sign 

3. Move the cursor to location E4. While you're moving the cursor, 
notice the current location indicator is remaining at location 
G4. When the cursor is at location E4, hit the '@' key. 

As you can see, when you hit the '@' key the system moves the 
cursor location into the edit line. The '@' key allows you to 
transfer a value at the cursor location into the current location 
without having to figure out the coordinate. 

In order to 'lock' the current location, you will need to type in 
something on the edit line before moving the cursor. For a 
numerical entry, a '+' or '-' sign will do and for a text entry, 
hitting the <space> key will wotk. 

4. Enter a '-' sign. 

5. Now move the cursor to F4 and then enter the '@' key and notice 
the result of P4 in your formula on the edit line. 

6. Hit <CR> and at the location G4, the contents line will read '+E4 
- F4 • , This is our formula for the profit/unit. 

At first glance this might seem to be more trouble than it's worth, 
but if you're working down below the 10th row, it may be easier to use 
the (3 function rather than pointing your finger on the screen trying 
to figure out the coordinate of the value you wish to use. 

The next step is to copy the formula for profit /unit into 
locations G5 through Gil with relative adjustments for each entry. 
After copying the formula you will find that the profits range from 
.005 (l/2cent) for the 1/4" bolt to .085 (8.5 cents) for the 1 1/2" 
bolt. 

In order for you to feel at home with the @ function, you may use 
it in entering the formula for %profit per bolt sold. The ^formula is 
profit/unit divided by the price and then mutiplied by 100, or G4/E4 * 
100. (HINT: remember to enter a '+' sign before 'G4'.) 

If your result at location H4 through Hll is '25.00', you may 
assume that you have understood these operations well. If you found 
the steps a little tricky, we'll take them one step at a time. 
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1. At location H4, enter a '+' sign 

2. Move the cursor to G4 and enter the '@' key '+G4' should 
now be on the edit line 

3. Enter the '/' sign (division sign) 

4. Move the cursor to E4 and enter the '(3* key 

5. Enter ' * 100' (multiply by 100) 

6. Hit the <CR> key 

(NOTE: for greater clarity, you could enclose '+G4/E4' in 
parentheses. If you do, remember to use the '^' key to 
change the entry type from text to numeric.) 

Finish entering the calculations for % profit by copying the 
formula at H4 into H5 through Hll with relative changes for each 
entry. 



11.16 THE WHAT COMMAND 

Before we proceed any further, let's take a minute to demonstrate 
another convenient command operation of LogiCalc. 

A. Simple What Command 

Move the cursor to location Hll. Now, if we were not sure what 
this value represented we would have to move the cursor up until we 
could see the column heading and then move the cursor back down to our 
entry at Hll (likewise, if there were row headings, we would have to 
move the cursor to the left and then back again) . Such movement can be 
frustrating and inefficient, especially if you forget what value you 
were at. A simple solution to this dilemma is to use the What command. 
With the cursor at Hll, enter ' ; ' and then enter 'W' . Underneath the 
edit line will appear 

row, column = ,% PROFIT 

This tells us row 11 has no title, but column H has the title '% 
PROFIT'. Clearly, this convenient operation can save you a lot of 
trouble when you need to reference specific rows and columns with 
dependent formulas . 

We're now going to let you practice for a little while on the 
various operations we have discussed so far. The next three columns 
are 'QUANTITY STOCKED', 'QUANTITY ON HAND', and 'QUANTITY ORDERED'. 
We'll give you the information for the number of bolts stocked for 
each size and the number of bolts on hand and let you enter the 
information and then write a formula to calculate the number of bolts 
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that should be ordered for each size. (Remember to use the Copy 
formula whenever you can. Use the @ function in writing your formula 
for the quantity ordered. 

The company stocks 5000 bolts of each size. The number of bolts 
on hand is as follows: 



1/4" bolt 

3/8" bolt 

1/2" bolt 

5/8" bolt 

3/4" bolt 

7/8" bolt 

1" bolt 

1/2" bolt 



2120 
2900 
3780 
3110 
4195 
3063 
1918 
4350 



Remember, there will be no fractions of a bolt, so set your decimal 
precision accordingly. To insure that everything is correct and the 
operations covered so far have been understood, let's check your 
results. In column I under 'QUANTITY STOCKED', there should be the 
integer '5000' in locations 14 through 111. Now move the cursor to 
location J4 and use the Edge command ('?E') to isolate the last two 
columns of figures for 'QUANTITY ON HAND' and 'QUANTITY ORDERED'. Your 
screen should resemble the following replication: 



Col> J 
Row+ 



**************** 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 



********************************************************* 

* 
* 

K L M : * 

* 



4 

5 

6 

7 

8 

9 

10 

11 

12 

13 



2120< 

2900 

3780 

3110 

4195 

3063 

1918 

4350 



2880 
2100 
1220 
1890 

805 
1937 
3082 

650 



* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
-* 
* 
* 
* 
* 
* 
* 
* 
* 

}* 
* 

* 

************************************************************************* 



cursor: J4 



current: : 
data : : 



current: J4 

type: numeric 
contents: 2120 
edit: 



^ ' , •? ' , <new data>, <arrows>, <ETX>, <TAB>, <CR>, ' ; commands: 
F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed 



*Commands :'(§', ' 

*{H)elp R)ecalc 

*{Q)uit G)oto I)nsert P)rint E)dge Order ?)storage W)hat =)lock 
* 
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The figures in column J are entered straight from the data given 
and the only change that was needed was to change the decimal 
precision from two places to zero places. At location K4 (QUANTITY 
ORDERED), the formula '+I4 - J4 ' should have been entered and then 
this formula should have been copied into locations K5 through Kll 
with relative changes. 

Well, take a deep breath. Only one more column of data to 
calculate. After that, we can really start to have some fun with our 
report. At location L4 we want to enter a formula (don't be too 
surprised!) and then copy it through the rest of the column with 
relative changes in order to show us the cost for this order for each 
size of bolt. 

At location L4 we can enter the formula for cost * quantity 
ordered to give us our results. So, enter ' +F4 * K4 ' to get the cost 
for this order for the 1/4" bolt. The result in the window at L4 
should say '43.20'. $43.20 worth of 1/4" bolts are being ordered at 
this time. Now copy the formula into locations L5 through Lll with 
relative changes. The results are: 



1/4" 


bolt 


43.20 


3/8" 


bolt 


47.25 


1/2" 


bolt 


41.17 


5/8" 


bolt 


95.68 


3/4" 


bolt 


61.12 


7/8" 


bolt 


220.63 


1" 


bolt 


526.58 


1 1/2" 


bolt 


166.58 


Extended What 







Now, in case you think the simple What command is not enough we 
have gone a step further and included the Extended What command. This 
will be of great help to you if you will be working in a section of 
the LogiCalc array in which you would constantly be needing to execute 
the simple What command to check whether your column and row location 
was correct. Instead of executing the simple What command repeatedly 
the Extended What command enables you to 'lock in' multiple rows 
and/or multiple columns. As a result, all the entries contained within 
the set of rows and columns which you specify will be constantly 
visible for you to refer to in order to insure you are making your 
changes in the right places. 

To show you how helpful the Extended What command can be, we will 
demonstrate a typical situation. Move the cursor to location LI 2. As 
you can see, it will not be real obvious as to what the numbers and 
entries represent. Now move the cursor back to location B2. We will 
now execute the Extended What several times to demonstrate several 
options. 
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To execute the Extended What command, follow the steps outlined 
below: 



computer prompt 



your response 



explanation 



edit ; 

Command = 

Lock: R)ow C)ol B)oth R, C, or B 



access command directory 
access extended What 
see below 



There are now three choices open to you. You may lock rows, 
columns, or both rows and columns. In order to lock one of these 
choices, type in either 'R', 'C, or 'B' . LogiCalc will then find the 
cursor location and will lock all rows and/or columns up to that 
location. This brings up a very important point. BE SURE TO LOCATE THE 
CURSOR IN THE APPROPRIATE LOCATION BEFORE EXECUTING THE EXTENDED WHAT 
COMMAND. That means, before typing ';=' move the cursor to the 
coordinate which will correspond to the rows /columns which you would 
like to "lock in". For instance, with the cursor at location B2, there 
are three possible actions which we could perform with the Extended 
What. These possibilities include: 



1. 



2. 



3. 



If we type 'R' to lock in rows then, with the cursor at B2, 
1 and 2 would be locked in; 



rows 



If we type 'C to lock in columns then, with the cursor at B2, 
columns A and B will be locked in? 

If we type 'B' to lock in both rows and columns then, with the 
cursor at location B2, both rows 1 & 2 and columns A & B will be 
locked in . 



By "locking in" we mean that the entries for those rows /columns 
that will always be displayed on the screen, no matter where you move 
the cursor. It follows that you should not try to lock in more than 10 
rows (or 15 rows for the extended screen - to be described later in 
this manual). This would serve no practical purpose as it would lock 
in the entire screen. 

Well, now that we have introduced the basics, we can illustrate 
our desciption with a few examples. With the cursor at location B2, 
execute the Extended What command as outlined above, then enter 'R' 
for the last prompt. Now you will see an '*' next to rows 1 and 2. 
This will help to remind you that rows one and two are locked in. Move 
the cursor to location LI 2. Your screen should resemble the following: 
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************* 

* 



* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 

*Coinmands : ' @ ' 
*{H)elp R)eca 
*{Q)uit G)oto 
* 
************* 



Col> J 
Row+ — 

1* 

2* 

8 

9 
10 
11 
12 
13 
14 
15 



************* * * ********************************************* 

* 

* 

K L I * 



QUANTITY ON HAND 



QUANTITY ORDERED 



COST /ORDER 



4195 
3063 
1918 
4350 



805 
1937 
3082 

650 



61.12 
220.63 
526.58 
166.58 



cursor: L12 



current: L12 



current 
data 



type : 
: : contents : 

edit: 

, •^•,'?',<new data>, <arrows>, <ETX>, <TAB>, <CR>, '; commands: 
Ic F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed 
I)nsert P)rint E)dge 0)rder ?)storage W)hat =)lock 

********************************************************** 



* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
_* 
* 
* 
* 
* 
* 
* 
* 

}* 
* 

* 

** 



Now, if we want to lock in columns instead of rows, we need to 
reaccess the Extended What command, unlock the rows, then lock the 
columns. Of course we must move the cursor to the appropriate column 
first, in order to insure that the number of columns we wish to lock 
in is correct. In order to make it as clear as possible, the steps are 
outlined below: 



computer prompt 



your response 



explanation 



edit 
Goto> Al 

edit 

Command 

Lock: R)ow C)ol B)oth 

edit 

Command 

Lock: R)ow C)ol B)oth 



<TAB> 
B2 



R 



access goto command 

move to column B so 2 
columns will be locked 

access command directory 

access Extended What command 

unlock rows 1 and 2 

access command directory 

access Extended What command 

lock in columns A and B 
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As you can see from the preceeding outline of steps, the 
procedure to unlock rows which have been locked in is to repeat the 
steps which you executed to lock the row in. By repeating these 
sequence of steps, you toggle the rows/columns from being locked to 
being unlocked or vice versa . 

Now, that we have executed the preceeding steps, move the cursor 
back to location LI 2 so we may see the benefits of having locked 
columns : 



*************************************************************** 

* * 

* * 

* Col>*A *B K L ! * 



Row+- 

7 

8 

9 
10 
11 
12 
13 
14 
15 
16 



12348 


5/8" 


BOLT 


12349 


3/4" 


BOLT 


12350 


7/8" 


BOLT 


12351 


1" 


BOLT 



12352 1 1/2" BOLT 



1890 

805 

1937 

3082 

650 



107.73 
61.12 
220.63 
526.58 
166.58 



cursor: L12 



current: L12 



current: : 
data : : 



type: 

contents : 

edit: 



* Commands :' @ ' , •^','?',<new data> , <arrows> , <ETX>, <TAB> , <CR>, '; commands : * 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto Dnsert P)rint E)dge 0)rder ?) storage W)hat =)lock * 
* * 

************************************************************************* 



It is now much easier to identify which bolts we are looking at 
the information for. With the Extended What command it is easy to see 
how many bolts we need to order for each size bolt and how much the 
order is going to cost. 

Now, if you really like to be spoiled, we can lock in both rows 

and columns. Certainly this will be the best of all possible worlds 

when we may see what the bolt sizes and part numbers are, and also see 

what column of figures we are examining - whether it is amount on hand 
or amount to be ordered, etc. 

To lock in both rows and columns, move the cursor back to 
location B2 and then execute the following sequence of steps: 



Page 42 



computer prompt 



your response 



explanation 



edit 

Command 

Lock: R)ow C)ol B)oth 

edit 

Command 

Lock: R)ow C)ol B)oth 



B 



access command directory 

access Extended What command 

unlock columns A and B 

access command directory 

access Extended What command 

lock in rows 1 and 2 and 
columns A and B 



Once these steps have been followed, goto LI 2 and your screen 
will appear similar to the following replication. 



********************************************************** 

* 

* 

* Col>*A *B K L . 



Row+- 
1* 
2* 
8 
9 

10 

11 

12 

13 

14 

15 



PART # PART NAME 



QUANTITY ORDERED 



12349 


3/4" 


BOLT 


12350 


7/8" 


BOLT 


12351 


1" 


BOLT 



12352 1 1/2" BOLT 



805 
1937 
3082 

650 



cursor: L12 



current: L12 



current: : 
data : : 



type: 

contents : 

edit: 



COST/ORDER 



*************** 
* 
* 

1 * 

* 

* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
.* 



61.12 
220.63 
526.58 
166.58 



* 
* 
* 
* 
* 
* 
* 
* 

}* 
* 

* 

************************************************************************* 



♦Commands : • @ ' , •^','?',<new data> , <arrows> , <ETX>, <TAB> , <CR 
*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat 

* 



> , ' ; commands : 
)uto T)ext ed 
=)lock 



Now you are free to move the cursor around as usual. The row and 
column headings will stay in place, available for easy reference. As 
you move the cursor to the left several times, you will notice the 
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screen scrolls before the cursor reaches the 'locked' column. The only 
way you will be able to move the cursor into column A or B is if the 
cursor is in column C. Then you may move into column A or B using the 
normal cursor movements. This situation is analogous for rows: The 
only way to move the cursor into row 1 or 2 is from row 3? otherwise, 
the screen will scroll up before reaching the row with the column 
headings. 

With the Extended What command you may scroll the cursor to 
anywhere on the LogiCalc array and the row and column headings will 
adjust to display the correct labels for the respective rows and 
columns . 

Once you have finished working with the example above, access the 
Extended What one more time and enter 'B' for both for the last prompt 
in order to unlock the rows and columns and return the screen to its 
normal display. 



11.17 SYSTEM FUNCTIONS AND USER DEFINED FUNCTIONS 

Now we have a chance to demonstrate two of the most powerful 
advantages of a computer report writer. LogiCalc includes five 
standard system functions: summation, average, maximum value, minimum 
value, and numeric count. In addition to this, LogiCalc provides you 
with the ability to define your own functions. You may define a 
function in one variable using the four standard arithmetic operations 
plus percentage. You may also use the standard system functions within 
your user defined functions and you may use conditional expressions 
(to be described in section 11.24 of this manual) within your user 
defined functions. Indeed, the sky is the limit concerning the number 
of applications available with system functions and user defined 
functions and the effort saved will be very satisfying. 

In Part A of this section we will describe the use of system 
functions and in Part B we will describe the use of user defined 
functions. Happy computing! 



Part A: System Functions 

In order to demonstrate system functions, let's say that we would 
like to know: the total cost of the order for all bolts, the total 
number of bolts stocked, on hand and on order, and the number of 
different bolts. Instead of counting in our heads or on our fingers 
and toes, the system will compute these values in one step by using 
system functions . 
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For instance, instead of writing a formula to add up L4 + L5 + 

... + Lll (to compute the total cost of the order), we can use one 

system function to compute it automatically. This would be even more 

useful if we had 50 parts in our inventory. Otherwise, our formulas 

would become unmanageable. 

At L12, use the repetition function (/=) to underline the column 
with dashes ('/=-')• Now, at location L13, enter ' +SUM (L4>L11)'. This 
will tell us: 

1. '+' - the entry is numeric, not text. You could 

also use the ' '^ ' "key. 

2. 'SUM' - the system function to calculate the sum 

of the given list of values. 

3. '(L4>L11)' - the range of values to be summed. Single 

values may be separated by commas and a 
range of values may be shown as they are 
in this example. You may sum any values 
from anywhere in the LogiCalc array. 

Once the above function is entered at LIS, you should see the 
result of 1202.24 in the window at L13. This means the total cost of 
the order was $1202.24. Wasn't that easy? 

Now, we can give you a little practice at working with system 
functions. Goto 112 and underline the column and then copy that from 
J12 through K12. Next, goto 113 and then enter the SUM function as 
shown above, with the range of 14 through 111. This will inform us of 
the total number of bolts that should be in the store (the result 
should equal 40000). You may repeat the SUM function for column J to 
find that we actually have 25436 bolts on hand. 

For column K, we can calculate the quantity ordered in one of two 
ways. We can either: 

1. Perform the SUM function for the range K4 through Kll 
or 

2. Subtract the total quantity on hand from the total 
quantity stocked ('+113 - J13 ' ) . (HINT: This method 
will compute a little more quickly than if you use 
a system function.) 

Either calculation will result in the correct answer of 14564 bolts on 
order. We will leave it up to you as to which you would like to use. 

We will demonstrate the use of one other system function. Goto 
A12 and underline the column as we have done previously. Here we want 
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to know how many different bolts we carry in our inventory. If we were 
to use the SUM function, we would calculate the suinmation of all the 
part numbers, but that would not be the right answer. Instead, we will 
use a system function called CNT (count) which will count the number 
of numerically valued entries in the argument list. 

At location A13, enter 'CNT (A4>A11)^^' C"^' is to switch the 
entry type from text to numeric). The result in the window at A13 will 
show '8'. We carry 8 different sizes of bolts. For clarification 
purposes, enter 'BOLTS' at location B13. The contents will be left 
justified and since the '8' is right justified, the result of columns 
A and B will show '8 BOLTS' 

In addition to the sum and count system functions, there are 
three other system functions available for general use. They are the 
average, maximum, and minimum functions. For a more detailed 
description, please refer to section II. 9. 



Part B: User Defined Functions 

Now don't hold your breath, but the fun is just beginning. We 
will now describe the procedure for defining your own functions in one 
variable . 

As an overview, when you would like to use a user defined 
function, move the cursor to the location where you would like the 
resulting answer to be displayed. At this location, you would enter in 
the expression which defines the function. Once the expression is 
entered, then, at the same location, type in the known value (the 
value for "x" if you wish) and LogiCalc will evaluate the expression 
in terms of the value you entered and display the resulting answer 
(the value for "y", where the function is of the form y=f(x) ). 

Now that you have a general idea of the format of the user 
defined function, we may cover a few specifics and then we will be 
able to illustrate with some examples. 

The expression may include any of the four standard arithmetic 
operations of addition, subtraction, multiplication, and division and, 
in addition (excuse the pun), may include percentages. The expression 
may also include any of the following elements: 

numeric constants; 
reference coordinates; 
system functions . 

The expression may return an arithmetic answer as a result of its 
computations, or it may return either of two results if the expression 
is conditional (logical true or false). In this section, we will not 
demonstrate the use of conditinal expressions in user defined 
functions, since we have not yet covered how to work with conditional 
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expressions. Once you are familiar with conditional expressions, it 
will only be a matter of exercise to come back to user defined 
functions and see how the two can work together. 

Well, it's time to illustrate these points with an example 
application. Let's imagine the sales manager came into your office 
where you have been working on your LogiCalc example file. The sales 
manager would like to know what the retail prices would be for the 1" 
and 1 1/2" bolts, if the price were to be raised either 50%, 75%, or 
125%. With a user defined function, our work will be minimized. By the 
way, you could also work the expression the other way around, to see 
what percentage price increase it would take to set the price at a 
level you would like to specify. 

Anyway, using one of the "goto" commands, move the cursor to 
location U3. At location U3 enter 'li%.22'. No, we did not make any 
typos... Let's explain the symbolism for entering user defined 
functions. The points below will explain the general steps and the 
specific steps for this example. 

1. When you would like to enter a user defined function at a 
coordinate location, the first character you enter should always 
be an ' i ' . This will inform LogiCalc that the following entry 
will be a user defined function. 

In our example, we have entered an 'I' as the first character, so 
LogiCalc will know what to do with it. 

2. Now enter the expression which you would like to have as your 
user defined function. Instead of entering 'x* for the variable, 
enter another 'i' for each occurrence of the variable. If the 
variable is being raised to some power, then you must enter as 
many ' i ' s as the number of powers the variable is being raised 
to. For example, if you have an equation such as 4x**2 + 3x + 5 
(four times x squared plus three times x plus five), you would 
enter ' 4*i* i+3* i+5 ' . This says to take 4 times x times x plus 3 
times X plus 5. The main point is to enter an 'I' for each 
occurrence of the value of the variable. 

In our example, we simply would like to find the value of various 
percentages of a fixed constant. The constant value '.22' is the 
current price for the 1" bolt. So, we enter 'i%.22' which says to 
take X percent of .22. We will now be able to enter in various 
values for the '!' to find the new price. 

You may now move the cursor to U4 and enter a similar function 
for the 1 1/2" bolt. Enter •ii%.34'. We now have the two functions we 
need to answer the sales manager's inquiries. 

Move the cursor back up to location U3 and enter ' 150 ' . The user 
defined function will now insert the value of 150 for the ' 1 ' and the 
expression will calculate the value of 150% of .22. This will inform 
us of the value which is a 50% increase over the previous price. The 
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result displayed at location U3 is '.33', which says if we increase 
the price 50% the new price of the 1" bolt will be $.33. Now, at the 
same location, enter '175' and the result will show that a 75% price 
increase will raise the price to $.38. Lastly, enter '225' and the 
result will show that a 125% increase will raise the price to $.49. 

To let the sales manager know the effects of the price increases 
on the 1 1/2" bolt, move the cursor down one row to location U4 where 
the second user defined function is stored. As before, enter '150' to 
obtain the result of a 50% price increase. The new price, displayed in 
the array at U4, is $.51. Enter '175' and the displayed result of $.59 
is the new price for a 75% price increase. Last of all, enter '225' 
for a 125% price increase and the result will be a new price of $.76. 
With this, we have calculated all the values the sales manager 
requested and the functions are still stored in the file. This means 
we may come back later and enter in more values if we would like to do 
so. 

The user defined functions are more abstract than the system 
functions since you have to enter the expression yourself. As a 
result, it is sometimes more difficult to find some applications. With 
time you will find that it is very handy to enter in expressions for 
which you frequently need to calculate one value given another value. 
Below we have listed a few sample applications just to give you an 
idea of the diverse ways in which you could apply the user defined 
functions. 



application 



formula 



LogiCalc entry 



finding approximate area of 

a circle pir**2 



13.1415*1*1 with r==l 



finding n raised to fourth 
power 



n**4 



1 i*l*i*j 



with n=l 



finding percentage price 

increases from raising 

prices to new point y%= 

(new price /old price) -100 



I ( I /old price ) -100 
with new price=l 



finding average of range of n 
entries and variable entered 

avg=(sum of range+x)/n+l 



lavg(F4>Fll, I) 
with x= i 



Page 48 



finding salesman's 

commission 10. 25%product. price il0.25%i 

with product price=i 

You will, no doubt, come up with your own applications for this 
feature, based upon the type of work your company is involved with. 
The important idea is that you have the capability, with LogiCalc, to 
perform such computations. 



11.18 THE \ FUNCTION 

The '\' function will allow you the opportunity to include a 
non-evaluated comment in a numeric entry in the LogiCalc array. This 
is very handy in case you are working in a section of the array where 
you cannot see the column and row headings easily. At the end of your 
numeric entry, enter '\<comment>' and the comment you insert can serve 
as a convenient reminder of what the entry represents. Your comment 
will not appear in the LogiCalc window or on a printout, but will be 
displayed on the contents line for the location with the comment 
insertion. 

As an example, move the cursor to location K13. This time enter 
' +SUM (K4>Kll)\total ordered'. The comment is not displayed in the 
window, but appears on the contents line. 

For your own practice, try entering comments at a couple of other 
locations. Be sure to hit the '\' key and not the '/' key. 

Take a minute to congratulate yourself - you have just finished a 
very thorough and accurate inventory record. All that remains to be 
demonstrated are commands to edit the file, print the file, quit the 
program and load the file back into LogiCalc. 

Before we make any changes, let's save the file again to make 
sure it is safe. Here are the steps, if you need a reminder: 



Page 49 



computer prompt 



your response 



explanation 



edit 

Command 

filename 



EXAMPLE 



file exists, do you wish to 

destroy old contents 

(Y/N?) Y 



Password ( <CR> = none) 



<CR> 



access command directory 

access Save command 

choose filename that you 
wish contents saved under 



update file to include 

the latest entries 

no specified password 



11.19 THE RECALCULATE COMMAND 

Next we may demonstrate one of the most useful commands of 
LogiCalc. After completing our inventory file, imagine you are handed 
a memo saying the cost of the 1/4" bolt has increased 10% and since 
the cost of all other bolts is based on the cost of the 1/4" bolt, 
then the cost of all bolts has increased as well. Since our values for 
cost, profit/unit, % profit and cost/order are all involved, this 
could be catastrophic information. Instead of drying your tears as you 
erase four columns of numbers, you can change one number and use one 
command to recalculate everything automatically. 

The first step is to use the calculator function to compute the 
new cost for the 1/4" bolt. On the edit line, enter '110%F4?'. This 
will inform you that the new cost of the 1/4" bolt is .0165. Now move 
the cursor to location F4. Enter the rounded off value of '.017' and 
check to see that the new value is displayed in the window at location 
F4. To execute the Recalculate command, duplicate the following steps: 



computer prompt 



your response 



explanation 



edit 

Command 

Recalculate 
E)ntry 



R 



- A) 11 or 



access command directory 
access Recalculate command 



we want all values to reflect 
the new cost, so recalculate 
all values. 
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The Recalculate command allows you to either recalculate all the 
formulas in the array or an entry that you specify. In our example, 
since profit /unit, % profit and cost/order were all influenced by the 
increased cost, we wanted the new figures for profit/unit, etc. But, 
in case you would like to recompute only one entry, while leaving 
everything else as it is, you may enter 'E' to recalculate the entry 
at the current location. 

If you enter 'A' to recalculate all the formulas, the Recalculate 
command examines each row and recomputes any formulas in that row. If 
any value which is used in a formula has changed, then the 
recalculated value will now appear on the screen. 

The system functions (e.g. SUM) are included in the Recalculate 
command and you can move the cursor to location LI 3 to verify that the 
total cost of this order has increased from its previous value to a 
new value of $1362.54. You may also check locations A13, 113 and K13 
to verify that our new information was included in the recalculated 
values for the system functions (QUANTITY ON HAND did not change 
because the value added was 0). 

(NOTE: If you try to recalculate an entry that contains text, the 
system simply does not calculate the entry and control returns to the 
edit line . ) 

Isn't that easier than wearing out your paper with an eraser? 
Imagine how much easier the Recalculate command would make your work 
if you were working from an approximate value towards an exact value. 
The use of the Recalculate command will be demonstrated several more 
times in the remainder of this manual. 

We should remind you of one point: Any entry which evaluates to 
something divided by zero will yield the 'Tn?* symbol upon 
recalculation. This symbol will also be displayed in any entries which 
are multiplied by or divided into or divided by an entry which equals 
a value divided by zero. For instance, if at location Al the value 
after recalculation is equal to 5/0 and location Bl contains the 
formula A1*A3 or A1/A3 or A3/A1 the '?n?' will be displayed in 
locations Al and Bl. 



11.20 THE ORDER COMMAND 

To view the Order command's submenu, follow these steps: 

computer prompt your response explanation 

edit ; access command directory 

Command O access Order command and 

will switch the evaluation 
order each time it is 
executed 
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The following submenu will appear: 



************************************************************ 

* * 

*Options : 0)rder[L-R] A)dvance[Of f ] R)ecalc[Off] Internal roundingCOff 3* 

* * 

************************************************************************* 



option 



explanation 



0)rder 



A)dvance 



changes the direction in which the array is 
evaluated; choices include left-to-right 
top-to-bottom (i.e., [L-R]) or top-to-bottom 
left-to-right (i.e., [T-B]). 



if 



R)ecalc 



if 



I)nternal rounding if 



'on", the cursor is automatically advanced 
to the next cell; if "off", the arrows on 
the keyboard must be used to manually 
advance the cursor to the next cell. 

'on", the values for the entire array are 
automatically recalculated each time a 
numerical value is entered; if "off", 
the array is recalculated only when the 
Recalc command in the main menu is pressed. 

'on", all values are rounded according 
to the degree of precision specified by 
the Format command; if "off", all values are 
truncated. 



Let's take a closer look at the submenu's Order option. The Order 
option determines which direction the Recalculate command moves in. 
Normally, the entries in the array are evaluated in a left to right 
direction through each column and then moving down to the next row and 
then moving from the left to the right and then to the next row and so 
on until all the rows have been evaluated. The Order option switches 
this order of evaluation so that entries are computed moving from top 
to bottom in each column and then moving one column to the right and 
moving from top to bottom again and so on until all the columns have 
been evaluated. 

order of evaluation 



left-to right top-to bottom 
12 3 4 5 
6 7 8 9 10 
11 12 13 14 15 
16 17 18 19 20 



top-to-bottom left-to-right 

1 5 9 13 17 

2 6 10 14 18 

3 7 11 15 19 

4 8 12 16 20 
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This diagram illustrates the two sequences of evaluation 
available with the Order option. The Order option is sometimes 
necessary because the Recalculate command, in moving through its usual 
order of evaluation (left-to-right top-to-bottom) , may encounter a 
formula that depends on a value at a coordinate that has not been 
evaluated yet and so the result at our formula will not be correct. 

For instance, if there were a formula at location D2 and the 
result of this formula depended on the value at B6 and if the value at 
B6 changed, then, when the Recalculate command was executed, the 
formula at D2 would be evaluated before the new expression at B6 and 
the result at D2 would be incorrect. If you were to switch the order 
of evaluation, however, the value at B6 would be reached before the 
formula at D2 was recalculated and the result would be correct. 

(NOTE: remember that left-to-right top-to-bottom is the standard order 
of evaluation. And, for purposes of illustration in this manual let's 
assume that the advance, recalculation, and internal rounding commands 
are turned off. ) 



11.21 THE MERGE COMMAND 

With the Recalculate command, you may produce new reports with 
new figures while preserving all the text entries of your original 
report, so that you do not need to write an entire report over just 
because the numerical data changes. There is another and perhaps 
easier way to preserve the report text while maintaining the ability 
to substitute new numerical data. The Merge command is especially 
helpful if you want to preserve your report text, but, because of 
complex dependencies and/or too many changing variables, the 
Recalculate command would be too complex to use to change numerical 
data. 

The Merge command allows you to create two or more separate files 
and then superimpose the files, one on top of the other. In our 
EXAMPLE file, we could create a standard inventory file which would 
contain the entries in columns A, B, C, D; contain the column headings 
for columns E, F, G, H; contain the entries for column I (the quantity 
stocked is constant); contain the column headings for columns J, K, 
and L. Let's call this file 'STDINV for standard inventory. 

In order to clearly understand the Merge command, we will include 
screen replications of what our fantasy files would look like if we 
were to go ahead and create them. You do not need to actually create 
them since this would involve quitting our present EXAMPLE file. The 
Merge command can be sufficiently understood by following along here 
in the manual. Illustrated below is the screen display that would 
result if we were to isolate columns C, D, E and F in our STDINV file. 
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* * 

* * 

* Col> CD E F : * 



Row+- 



3 
4 
5 
6 
7 
8 
9 
10 



> SUPPLIER #< 



SUPPLIER NAME 



PRICE 



COST 



35 
35 
35 
83 
83 
83 
83 



ACME 
ACME 
ACME 
UNIVERSAL 
UNIVERSAL 
UNIVERSAL 
UNIVERSAL 



cursor: CI 



current: : 
data : : 



current: CI 

type: text: right justified 
contents: SUPPLIER # 
edit: 



♦Commands: *^' , '"','?', <new data>, <arrows>, <ETX>, <TAB>, <CR>, ' ; 'commands:* 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?) storage W)hat =)lock * 
* * 



As you can see, the values for the price and cost of all the 
bolts have been left out of the STDINV file. The reason for this is 
the information contained in the STDINV file is subject to very little 
change and therefore can be stored in a separate file and used 
whenever needed. All the information that is subject to change can be 
stored in other files and then, when the Merge command is executed, 
the two files can be combined into one. Yet, even when the two files 
are combined, your original STDINV file is stored in its original 
condition on the disk to be used again whenever you wish. 

Now, we could create another file called 'INVDATA' (inventory 
data) which would store the changeable values including: price, cost, 
profit/unit, % profit, quantity on hand, quantity ordered and 
cost/order. All of these numbers are subject to change. Now we can 
take a look at the screen display for the INVDATA file at the same 
location of the array as the screen display for the STDINV file. 
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************************************************************** 

* * 

* * 

* Col> C D E F : * 

* 'D i^T.TO. _________ _^__^_..____— _ — __ — ~i~-._~ — »_- — — — >— — — — ^»i — — •->•>. — ^— _ — __ — _ — ___ — ...i.__>-* 



Row+- 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 



0.02 
0.03 
0.04 
0.06 
0.10 
0.15 
0.22 



cursor: CI 



current: CI 



current 
data 



type: 

contents : 

edit: 



0.017 
0.025 
0.038 
0.057 
0.086 
0.129 
0.193 



♦Commands: '(§', •"','?', <new data>, <arrows>, <ETX>, <TAB>, <CR>, ' ; 'commands:* 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat =)lock * 
* * 

************************************************************************* 



The INVDATA file contains only the numerical data information 
that is variable. Therefore, instead of writing an entirely new report 
each time the data changes or having to try and edit a file with 
complicated dependencies and formulas, we can create a new file with 
the new data and then merge the new file with our STDINV file. The 
Merge command will also be useful if we have several files of data. We 
can perform the merge operation and then print or display the results 
and then merge two more files and print or display the results and so 
on. By using the Merge command you do not need to spend the time 
re-entering and recalculating numerical data. 

Something that is especially useful is the ability to choose the 
location for the upper left hand corner of any of the Merge files. 
This will allow you to design little modules. You will then be able to 
mix and match them however you choose on the LogiCalc array to produce 
a wide variety of report and model combinations (and be able to 
greatly minimize duplicated work) . 
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The steps to merge the two files are as follows: 
computer prompt your response explanation 



edit 

Command 

filename 



load position: Al 



M 
STDINV 



<CR> 



access command directory 

access Merge command 

merge INVDATA with our 
other fantasy file 
called standard 
inventory 

we would like the upper left 
corner of STDINV to be at 
Al 



The default value for the merge position is the location of the 
leftmost entry in the top row at the time the when the file that is 
being merged was saved, in this case Al. 

The results of merging our STDINV file with our INVDATA file at 
the same location as the illustrations above is shown below. 

* * 

* * 

* Col> CD E F : * 



Row+- 
1:> 



3 
4 
5 
6 
7 
8 
9 
10 



SUPPLIER #< 



SUPPLIER NAME 



PRICE 



COST 



35 
35 
35 
83 
83 
83 
83 



ACME 
ACME 
ACME 
UNIVERSAL 
UNIVERSAL 
UNIVERSAL 
UNIVERSAL 



0.02 
0.03 
0.04 
0.06 
0.10 
0.15 
0.22 



0.017 
0.025 
0.038 
0.057 
0.086 
0.129 
0.193 



* 
* 

* current:: 

* data : ; 
* 

* 

* 



cursor: CI 



current: CI 

type: text: right justified 
contents: SUPPLIER # 
edit: 



♦Commands: '@' , '^' , '? ' , <new data>, <arrows>, <ETX>, <TAB>, <CR>, ' ; ' commands:* 
*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 
*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat =)loc'k * 
* * 
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The result of the Merge command is the combination of both the 
STDINV file and the INVDATA file onto one screen and this will exactly 
duplicate our EXAMPLE file with all information included. 

The only caution with the Merge command is that the file being 
merged on the screen will override the original file in terms of the 
column widths, precisions, etc. If both files have entries in the same 
location, the entry from the file being Merged onto the array will 
replace the entry which was originally on the array. This is why it is 
a good idea to put your files together in little modules rather then 
spread out templates . 

VThen you Merge a file onto the array with the upper left hand 
corner at a different location than when you originally created it, 
there is a potential for disaster since formulas which use entry 
locations are not located in the same place as the file they were 
created in. LogiCalc takes care of this problem by adjusting formulas 
when they are moved into the Merged file. This is true for all 
formulas which reference locations within the module being merged. 
However, any formulas which reference locations outside of the module 
being transported will not yield correct results in the resulting file 
because the resulting file probably will not contain the same data at 
the external location as the file from which the module with the 
external referencing formula was taken. The moral of the story is to 
be sure that all modules you are merging into new files only contain 
formulas which reference locations internal to the module. 



11.22 THE INSERT COMMAND 

Now is a good time to demonstrate a very important editing 
operation which allows you to insert a column or row into your report. 
This becomes very handy if you have some new information which you 
need to add to your report, but you presently do not have the room. 

Let's imagine, once again, another memo has been handed to you 
from upstairs informing you that the company has started to stock a 
new item - a 1 1/4" bolt. The company would like you to add this new 
item to your inventory and include it on your present report. Of 
course, if we didn't have LogiCalc, we would have to start all over 
and write a new report. With LogiCalc, however, we can insert a row 
and add the information for your new bolt, then have LogiCalc 
recalculate all the formulas. 

Move the cursor to All (the cursor may actually be anywhere on 
row 11). To execute the Insert command, follow these steps: 
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computer prompt 



your response 



explanation 



edit ; 

Command > I 

Insert: R)ow C)olumn R 



access command directory 

access Insert command 

insert a row for our new 
information 



Row 11 has now been moved down to become row 12, row 12 has been 
moved down to become row 13 and row 13 has become row 14. Row 11 is 
now a blank line. So, LogiCalc will automatically renumber rows and 
columns to account for newly inserted rows and columns and will 
transfer all data to the newly renumbered rows and columns. 



Now we can enter the new information 
inventory file. The data is as follows: 



for our addition to the 



part # 12353 

part name /Rl 1/4" BOLT 

supplier # 35 

supplier name ACME 

price . 28 

cost .238 

profit/unit +E11 - Fll 

% profit +G11/E11 * 100 

quantity stocked 5000 

quantity on hand 

quantity ordered +111 - Jll 

cost/order +F11 * Kll 



You may use the Recalculate command to recompute all the totals 
to include the information you have just added to the file. So, within 
5 minutes of receiving the memo you can present the new report 
information. Doesn't that make you sigh in relief? 

One important point to bring out here: If there are dependencies 
in the vertical direction (e.g. All dependent on A10) at or below the 
newly inserted row, then the formulas for calculating the values in 
those rows will remain the same even though the rows have been moved 
to a new location. As a result, if your newly inserted row of 
information will contain data or formulas which will alter the value 
of the entry of a row which has been moved (e.g. if you want to 
maintain a sequential list of numbers) then you will have to alter the 
formula for all of the rows below the newly inserted row. 

This can easily be fixed by entering in a new formula at the row 
just below the newly inserted row and then copying the formula with 
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relative changes. Unfortunately, these changes must be done by hand 
since the computer doesn't know whether the information in the newly 
inserted row will affect the rows beneathe the new row. Computers 
cannot read our minds - at least not yet I 

In the same way you inserted a row, you may also insert a column. 
If, for instance, you would like to add a new category of information 
in your file, you may do so by inserting a column wherever you would 
like. As an illustration, you could insert a column for the supplier 
phone number (for placing orders). With the cursor at the price 
column, you could insert a column by following the steps outlined 
above and entering 'C' (for column) instead of 'R' (for row). This 
would leave column E blank and would move each of the other columns 
over one column to the right. You could now enter in your supplier 
phone numbers in column E. At this point, we will leave the supplier 
phone number column out of our EXAMPLE file. 



The editing function that goes hand in hand with the 
command is the Delete command, which we shall now describe. 



Insert 



11.23 THE DELETE COMMAND 



As a result of another infamous memo we now find we must delete 
some information from our file. Based on a marketing study, the 
company has made a decision to stop carrying the 1 1/2" bolt. This 
memo becomes effective with our current report and so we must change 
it again. As a result, we will have to delete all the information 
pertaining to the 1 1/2" bolt and recalculate the total: cost/order, 
quantity ordered, quantity on hand, quantity stocked and the number of 
different bolts. Again, without LogiCalc, this would mean rewriting 
the entire report and recalculating all the values. Instead, we may 
use one command to delete the information and use one other command to 
recalculate all the formulas and our report will be updated. 

Move the cursor to location A12. To execute the Delete command, 
duplicate the following steps: 



computer prompt 



your response 



explanation 



edit 
Command 



access command directory 
access Delete command 



Delete: A) 11 R)ow 
C)oluran E)ntry 



R 



to delete the row in 
which the cursor is 
located 
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If you have performed the above steps, the following error 
message will be displayed: 

ERROR: would delete ref(s) at A14, 114, J14, L14 

As you can see, the Delete command will not let you delete any 
location which has other values dependent on it. This is a blessing, 
since you could accidentally delete values which would cause many 
other values to become undefined as a result. In order to delete 
entries that have other values dependent on them, you need to change 
the formulas that are dependent on the values you would like to delete 
and then the system will let you delete them. 

In order to change the formulas that are dependent on the row 
which we would like to delete, follow these steps: 

1. Goto A14. Change the entry to •+CNT (A4>A11)' 

2. Goto 114. Change the entry to '^-SUM (I4>I11)' 

3. Goto J14. Change the entry to ' +SUM (J4>J11)' 

4. Goto K14. Change the entry to '+SUM (K4>K11)' 

5. Goto L14. Change the entry to ' +SUM (L4>L11)' 

Move the cursor to location A12 . Now repeat the above steps to 
execute the Delete command. This time, after you enter 'R' to let the 
system know that you would like to delete row 12, the prompt will ask: 

Verify Y/N - 

This prompt insures that you really would like to make the deletion 
that you say you want to. It insures against accidentally deleting 
something that you really would like to save. If you answer 'N' , the 
Deletion comand will be aborted and control will return to the edit 
line. If you answer 'Y', the deletion will occur and then any 
following rows or columns will be moved up or to the left to fill in 
the gap of the deleted row or column. 

The other deletion choices besides row are: 



entry 



If you enter 'E' for the deletion prompt, the system 
will delete the entry at the current location indicator 
without asking to verify the deletion. If there are 
other values dependent on the entry you would like to 
delete, the deletion WILL occur. 
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column 

If you enter 'C for the deletion prompt and there 
are no other values that are dependent on any of the 
values in the column you are trying to delete, then 
the system will ask you to verify the deletion. If 
you enter 'N', the deletion will not occur. If you 
enter'Y', the deletion will occur. If there are any 
values anywhere in the report that are dependent on 
any of the values in the column you are trying to 
delete, the deletion will not occur and an error 
message will be displayed. 

all If you enter *A' and then enter 'Y' to verify the 

deletion, all the information on the screen will be 
deleted. Whatever is still on the disk from the last 
time you saved the file will still be safe and 
available for you to load back into LogiCalc, BUT all 
the changes made since the last time you saved the file 
will be erased. If you answer 'N' to the prompt to 
verify the deletion, the deletion will not occur and 
control will return to the edit line. 

NOTE: LogiCalc is designed so that if you delete any entries, you will 
increase your available memory space. In other words, LogiCalc 
reclaims all deleted entries and recycles them for future use. 



11.24 CONDITIONAL EXPRESSIONS 

We may now introduce one of the most sophisticated abilities of 
LogiCalc. The ability to incorporate conditional statements into a 
financial report generating system is very useful. A conditional 
statement will evaluate the condition you enter and then, depending on 
whether the condition is true or false, the system will execute one 
statement you specify if the condition is true or else it will execute 
another statement that you may specify if the condition is false. This 
opens up virtually unlimited possibilities, so let's demonstrate a 
simple example, then generalize on further possibilities. 

For our first conditional example, let's examine the case of what 
happens when we have more parts on hand than we usually stock for any 
one particular good. As the report stands at this time, when the 
amount on hand is subtracted from the amount stocked, a negative 
answer will result. This answer is multiplied by the cost and will 
yield a negative total cost for amount ordered of this part. 

This presents a problem since it is doubtful we will be able to get 
our suppliers to pay us for ordering parts from them I Our solution is 
to use a conditional expression to determine whether the amount on 
hand is greater than the amount stocked. If it is, the amount ordered 
will become 0. If the amount on hand is less than the amount stocked, 
then we will subtract in the way we have been doing in order to find 
out how many parts we should order. Are you ready to try this out? 
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The summary of actions is shovm below. You may follow along; we 
will explain the general form of how to enter conditional statements. 
First, move the cursor to location K4 , 



computer prompt 



your response 



explanation 



edit 



+J4<I4:I4 - J4 



edit 

goto> Al 
edit 

edit 

Command 

Recalculate 
E ) ntry 



<TAB>(or ;G) 
J4 
6000 



R 



- A)ll or 



IF the amount on hand (J4) 
is less than amount stock- 
ed (14), THEN subtract J4 
from 14 and enter into K4# 
ELSE the value at K4 will 
be because a false con- 
ditional statement is 
assigned the value of 

access goto command 

move to J4 

change data entry to tell 
us we have 6000 parts on 
hand 

access command directory 

access Recalculate command 



recompute results to reflect 

new data 



Now the result in K4 will show that the quantity ordered is 0. 
This is very helpful for us in keeping our records straight and not to 
try and order negative amounts of a part. If you would like, you may 
take a minute to check all the totals influenced by this change and 
see that they are correct. Isn't that fantastic? Now to check that the 
conditional statement works the other way, enter '2120' at J4 (this 
was our original amount) and then recalculate to display our original 
totals. 

Let ' s take a minute to describe the general format of a 
conditional statement before going on to the next step. The general 
format of a conditional statement is: 

condition: executable statement if condition is true: executable 
statement if condition is false 

Translating the conditional statement to English might result in the 
following: "IF the condition is true, THEN execute the first set of 
statements, ELSE (otherwise) execute the second set of statements". 
Let's review some points about each of the three parts included in a 
conditional statement. 
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condition 

the condition may include numerical values and coordinate 
references. Be careful to only include single coordinates 
as the symbol for a range ( ' > ' ) would be interpreted as the 
relational operator "greater than". To be able to include 
ranges of values, use a system function to sum or average, 
etc. The values may be operated on by relational operators, 
logical operators, arithmetic operators and any combination 
of the three. The relational operators included are: 

< (less than) 

<= (less than or equal to) 

= (equal to) 

<> (not equal to) 

>= (greater than or equal to) 

> (greater than) 

The logical operators included are: 

* (logical AND, the intersection of two values. 
Typically, both values must be true for the 
entire expression to be true) 

+ (logical OR, the union of two values. Only one 
of the two values will need to be true for the 
entire expression to be true) 

The arithmetic operations included are the same as you 
have already been working with in LogiCalc (e.g. 
addition, percentage, etc.). For numerical manipulation 
with conditions evaluated to true or false, the 
true condition will assume a numerical value of 1 and 
the false condition will assume a numerical value of 0. 

executable statement if condition is true 

after the first colon ( ' : ' ) you may enter the statement you 
would like to be executed if the condition- is true. This 
statement will be executed only if the condition is true. 
The statement may be a number, a coordinate, a formula 
involving any combination of both, or a string of five or less 
characters enclosed in double quotes (e.g. "yes"). If you enter 
a condition followed by two colons, the value assigned will be 
zero if the condition is true. 
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executable statement if condition is £alse 

after the second colon you may enter a statement you 
would like to be executed if the condition is evaluated 
to be false. This statement is optional and if you 
do not enter a statement, will be entered if the 
condition is false. This was the case with our first 
example above. The statement may be a number, a coordinate, 
a formula involving any combination of both or a string of 
characters enclosed in double quotes. 

With all this in mind, we may now go on to demonstrate a few 
additional examples involving conditional statements. 

For our second example, we may attack the same problem we solved 
in our first example, except we will solve it in an alternative way. 
With the cursor at K5, enter ' ( J5 <I5)* (I5-J5 ) ' . This will evaluate the 
first expression '(J5<I5)'. If the condition is true, the expression 
is assigned a value of 1 and 1 is multiplied by the result of the 
second expression *(I5-J5)' to obtain the number of parts on order, 
entered into location K5. 

If the first expression is false, the expression is assigned a 
value of and is multiplied by the second expression to obtain a 
result of 0. So, this expression will yield the same result as the 
first example. To verify this, change the on hand amount (J5) to 
' 7000 ' and then recalculate and observe the amount ordered to be ' ' 
at K5. Again, to check that the 'true' value of the conditional 
statement evaluates properly, re-enter ' 2900 ' at location J5 and then 
recalculate and compare these totals to our original totals. 

In our third example we will demonstrate the use of the OR 
logical operator. In this example, you may imagine that the management 
has asked you to compose a list of all the parts in which the 
cost/order is greater than $200.00 OR the quantity on order is more 
than 20% of the quantity that is usually stocked. This is a list of 
your best selling parts or your parts that bring in the most profit. A 
part may satisfy either one of these conditions to get on the list. 
Since this is not a part of your official report, but you would like 
to keep it in the same file in order to be able to print the list 
later, we will move the cursor out to column N to store our list. 

At location N4, enter ' (K4>20%I4)+(L4>200.00 ) ' and then copy the 
formula into locations N5 through Nil with relative changes. The 
following screen display will occur: 
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**************** 

* 



Col> M 
Row+ 

1 

2 

3 

4 

5 

6 

7 

8 

9 
10 



current: : 
data : : 



♦Commands : ' @ ' , ' " 

*{H)elp R)ecalc 

*{Q)uit G)oto I) 
* 



********************************************************* 

* 
* 

N O P : * 

-.-.-- _._. * 

* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 

* 
* 
* 



1.00< 

1.00 

1.00 

1.00 

0.00 

2.00 

2.00 



cursor: N4 



current: N4 

type: numeric 
contents: (K4>20%I4)+(H4>25 .00) 
edit: 



','?•,< new data>, <arrows>, <ETX>, <TAB>, <CR>, ' ; ' commands: 
F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed} 
nsert P)rint E)dge 0)rder ?)storage W)hat =)lock U)disk} 



************************************************************************ 



This will inform you the parts in rows 4,5,6, and 7 satisfy one 
of the conditions, the parts in rows 9,10 and 11 satisfy both of the 
conditions, and the part in row 8 satisfies neither condition. Thus, 
you have the means to produce the result desired by your managers 
including the ability for them to scale how well the products are 
doing in relation to one another. 

We will demonstrate one other example of how to scale the success 
of your parts using an alternative structure. In this case, we will 
assign a value of 100 to those parts which satisfy both of the 
conditions of having the amount on order be more than 20% of the 
amount stocked and the cost /order be greater than $200.00. We will 
assign a value of 50 to any part which does not satisfy both of these 
conditions. To accomplish this task, move the cursor to 04 and enter 
' (L4>200)*(K4>20%I4):100:50' . Note that the '*' implies the use of the 
logical operator AND; but is, in this case, identical in result to the 
multiplication operation. If either expression is false it's numerical 
value becomes and multiplied by anything results in 0. So, both 
expressions must be true for a part to be valued at 100. Otherwise it 
is valued at 50. After you copy the formula with relative changes, 
your screen will show the following display: 



Page 65 



* 
* 

* Col> M N O P : 



Row+- 

1 

2 
3 

4 
5 
6 
7 
8 
9 
10 



1.00 > 

1.00 

1.00 

1.00 

0.00 

2.00 

2.00 



50.00< 
50.00 
50.00 
50.00 
50.00 
100.00 
100.00 



* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 

* 
•k 
•k 
* 
* 

♦Commands : * @ ' , * ^ ' , ' ? ' , <new data> , <arrows> , <ETX> , <TAB> , <CR> , ' ; ' commands : 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opY D)elete M)erge A)uto T)ext ed} 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?)storage W)hat =)lock U)disk} 
* 



cursor: 04 



current: : 
data : : 



current: 04 

type: numeric 
contents : (H4> 25 ) * (K4> 20%I4 ) : 100 : 50 
edit: 



Now that you have the format for conditional statements down, 
let's throw one more option into the picture. With LogiCalc, you may 
also incorporate nested conditional expressions. Nested conditional 
expressions are just a variation of the simple conditional expression. 
A nested conditional expression means that the false result of a 
conditional expression may be another conditional expression itself. 
Thus, the second conditional expression is "nested" within the first 
conditional expression. 

If one were to translate this version of the conditional 
expression into English, it would come out something like this: "IF 
condition is true THEN do first statement ELSE IF second expression is 
true THEN do second statement ELSE do third statement". 

Let ' s take a momentary break from our inventory example to 
imagine one of the many situations where this feature could be useful. 
Imagine a salesman's monthly sales figure is contained in location D6 
and is measured in thousands of dollars. Now, imagine you would like 
to calculate his (or her) bonus and you have three bonus categories 
based on volume of sales. The following nested conditional expression 
would yield the desired bonus. 

D6>100:5%D6:D6>50:3%D6:1%D6 
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Now this may look like garbage data, but it's actually a very useful 
formula. It says, if sales (contained in D6 ) are greater than 100 
thousand, then the bonus is equal to five percent of the sales, else 
if the sales are greater than 50 thousand, then the bonus is equal to 
three percent of the sales, else the bonus is equal to one percent of 
the sales. 

With a little imagination you can imagine how useful and powerful 
nested conditional expressions can be for a financial modeling system. 
The only limitation that exists is that a mathematical expression may 
be no longer than 34 characters. Thus, it is useful to abbreviate as 
much as possible. As an example, storing the sales figures in units of 
thousands of dollars. 

One last reminder might be helpful at this point. When you are 
working with complex expressions, it is important to keep in mind the 
order in which they will be evaluated. On a computer, all of the 
multiplication and division operations will be executed before any of 
the addition or subtraction operations. The only way to alter this 
order of evaluation is to use parentheses in the appropriate places . 
Any operation enclosed by parentheses will have a greater priority 
than those not enclosed in parentheses. Inside parentheses evaluation 
will follow the normal order of mutiplication and division, then 
addition and subtraction. Therefore, use your parenthesis carefully in 
order for your expressions to yield the results you intend they should 
yield. 



11.25 THE AUTOMATIC FORM COMMAND 

The Auto command is utilized to make it more convenient to edit 
specific entries that are highly subject to change. The Auto command 
is used in conjunction with the form mode specification of the Format 
command . 

The way it works is to move the cursor to an entry, set the form 
mode, move the cursor to another entry and set the form mode and so on 
until you have set the form mode for all the items of data in your 
file that are highly subject to change. Now, execute the Auto command 
and the cursor jumps to the first entry at which the form mode is set. 
The Auto command has automatically deleted the previous value in that 
entry and you may now put in your new information. When you hit <CR> 
the cursor jumps to the next entry in that row or to the first entry 
in the next row at which you set the form mode, deletes the previous 
value at the entry and you may enter your new information. The Auto 
command proceeds in a row by row order through the file, one entry at 
a time for each time <CR> is entered. 

The purpose of the Auto command, as was stated, is to save you 
from having to hunt around the array looking for a specific piece of 
information. With the Auto command, you may automatically jump from 
entry to entry and make your editing work a lot easier. 
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In our EXAMPLE file, the two categories of data which are most 
subject to change are QUANTITY ON HAND and COST. We will demonstrate 
how much easier it is to edit using the Auto comand. 

First of all, goto F4. Here are the steps necessary to set the 
form mode: 



computer prompt 



your response 



explanation 



edit ; 

Command F 

P)recision(0) or W)idth(24) 

or Form Mode (clear) F 



access command directory 
access Format command 



set form mode at current 
location 



The message now displayed below the edit line reads 

Form Mode (set) 

Repeat this procedure for locations F5 through Fll and J4 
through Jll. We will re-enter the information shortly. 

Once all the form modes have been set for the values in 
columns F and J, move the cursor back to location Al. Now 
imagine that you have received updated information for 
the cost of the bolts and the present quantity on hand. Instead 
of moving the cursor all over, we may execute the following 
steps to input our new data: 



computer prompt 



your response 



explanation 



edit 
Command 



access command directory 
access Auto command 



The cursor jumps to location F4, the entry where the first 
form mode was set. The entry is blank and waiting for a new 
cost value. Enter '.017'. When you hit <CR> the entry is made and 
cursor jumps to location J4, the next form mode on row 4. 
At J4, enter '2120', our new data for the number of 1/4" bolts 
on hand. Once again, when you hit <CR>, the entry is made and 
the cusor jumps to location A5. 



Page 68 



You may continue to use the Auto command in this same way to enter the 
rest of the data. 



F5 


- 


.025 


F6 


- 


.038 


F7 


- 


.057 


F8 


- 


.086 


F9 


- 


.129 


F10 


- 


.193 


Fll 


- 


.238 



J5 


- 


•2900' 


J6 


- 


'3780' 


J7 


- 


'3110' 


J8 


- 


•4195' 


J9 


— 


•3063' 


J10 


- 


'1918' 


Jll 


-. 


'0' 



(NOTE: remember, if you would like to abort the Auto command before 
you have finished entering information for all of the form mode 
locations, you may hit <esc> and control will return to the edit line 
and the message below the edit line will read Auto aborted. ) 

If you decide that you would like to switch some of the form 

modes from set to clear (back to their original condition) so that the 

Automatic form command will not jump to these locations, then follow 
these steps to undo the set form mode : 



computer prompt 



your response 



explanation 



edit 

Command 

P)recision(2) or W)idth(10) 
or Form Mode (set) 



access command directory 
access Format command 



change form mode from set 
to clear 



With the form mode clear, the Auto command will no longer jump to 
this location. 

You may have noticed the figures for some of the computed values, 
such as %PROFIT are now different than before we executed the 
automatic form mode feature. The reason for this is that previous to 
our execution of the automatic form mode, the values were computed 
using the internal representation of the numbers (which you could 
display by increasing the decimal precision of the column) and when we 
re-entered the numbers using the automatic form mode feature, the 
numbers were not as accurate to as many places because we were only 
interested in, at most, three decimal places. The moral of the story 
is to use the precision option of the Format command to display 
numbers to as many decimal places as you would like the accuracy to 
extend, with a maximum of 10 decimal places imposed by the program. 
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11.26 THE PRINT COMMAND (ENTIRE FILE) 



At last we have come to the point where we are ready to print out 
the results of all your hard work on this example file. There is a lot 
of flexibility with the Print command and as a result there are 
several prompts involved before the printing takes place. This 
flexibility, however, allows you many possibilities in specifying what 
you may have on your printout In order to fully demonstrate the 
flexibility of the Print operation, we will break it up into two 
different sections. This section will give an example of how to print 
out an entire file. Section 11.27 will give an example of how to print 
out a subsection of a file. 

To begin the Print operation, proceed through the following 
steps : 



computer prompt 



your response 



explanation 



edit ? 

Command P 

To which file? PRINTER <CR> 



access command directory 
access Print command 
see below 



The last question above informs you that you may either print out 
your report to another file on the disk or to the printer for a hard 
copy. If you would like to print the report to a file on the disk, 
then enter the name that you would like the report to be stored under. 
Once the report is stored in a file on the disk you may use it in a 
word processing environment as we will describe in the next section. 
If you would like a printout, then enter <CR> and by default your 
report will be sent to the printer. For our EXAMPLE file, enter <CR> 
so you may have a printout of the report. The next prompt will ask: 



top left corner of form: Al 



At this point, you may specify the location on the array (i.e. 
some coordinate) that you would like to become the top left-hand 
corner of your printout. The prompt is included in case you would like 
to print out only a portion of the report which did not include the 
upper left-hand corner of the array (i.e. location Al ) . We will 
demonstrate this in the second example (section 11.27) of this manual. 
For now, we would like to print out the entire file, so enter <CR> or 
*A1' as shown below: 



Page 70 



top left corner of form: Al 



After entering 'Al ' or hitting <CR>, the next prompt 
will ask: 



bottom right corner: Jll 



Jll is displayed as the default location because it is the last 
coordinate in which the cursor was located. The Print command will 
always take the cursor location as the default value for the bottom 
right corner of the printout. 

Now you are being asked to specify what you would like to be the 
bottom right hand corner of your printout. At this point you have to 
be a little careful. If your report is wider than the maximum printing 
width of your printer, then you will need to have your report printed 
out in segments and patch it together afterward. The default value for 
the bottom right corner is the present cursor location. If this is not 
the point you would like to have for the bottom right of your report, 
then enter the correct location or move the cursor to the location and 
type the ' @ ' symbol . 

In our example we will assume the use of a printer with a 
printing width of 80 characters in order for our example to be 
universally applicable. Since our report is wider than 80 characters, 
we will be able to demonstrate how LogiCalc automatically divides our 
report into segments to fit our printing width. In this first printing 
example we are printing out the entire report so enter the coordinate 
which corresponds to the bottom right corner of the report. In our 
EXAMPLE file move the cursor to LI 3 and type '@'. The result is shown 
below. 



bottom right corner: L13 



(HINT: if you don't remember what the last row with information is, 
use the cursor control keys to help you find out, then use the '0' 
sign to enter the appropriate coordinate.) 
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The following prompt will be: 



form length: CONTINUOUS 



This prompt allows you to decide how many lines per page you 
would like printed. If you would like the printout to be continuous 
from page to page, then hit the <CR> key and the next prompt will be 
presented. If you would like less than 66 lines per page (standard 
type) printed, then enter your choice between 1 and 66. For our first 
printout, answer this prompt with '60' as illustrated below: 



form length: 60 



After you have specified the number of lines per page to be 
printed (provided you did not hit <CR> for continuous printing) the 
system will prompt: 



stop on each page (y,n)? 



If you decide you would like the printing to stop after each page is 
printed, then enter 'Y'. You will be able to resume the printing by 
hitting the <space> key. If you decide that you don't need the 
printing to stop after each page, then enter 'N' and the system will 
print the specified number of lines per page until the entire section 
has been printed. For instance, we would like the printing to execute 
without stopping, so enter 'N' as shown below: 



stop on each page (y,n)? N 



Page 72 



Whether you decide that you would like continuous printing or you 
specify a printing length, the next prompt will ask: 



printer width: 132 



Now, you may choose the number of spaces across the page you 
would like the file to be printed in. This will partially depend on 
the paper size and the type size. If you are using the 11" wide paper, 
you may specify the standard printing width of 132 spaces across the 
page by hitting <CR> . Otherwise, if you would like less than 132 
spaces printed across the page, enter a number between 1 and 132. If 
you are using the 8 1/2" wide paper, then enter a number between 1 and 
80 (the maximum number of spaces across for 8 1/2" wide paper). 

One very important reminder is to make sure that the printing 
width you specify is wide enough to fit the portion of the array you 
would like to be printed out. For example, do not specify a printing 
width of 50 if you would like 80 spaces of data to be printed out. 

In order to be universally applicable, we will specify a printing 
width of 80 for our printout of the file EXAMPLE, so enter '80* as 
illustrated below: 



printer width: 80 



Once you have entered a figure for the printing width, the screen 
will be cleared before presenting the last few prompts. The reason for 
clearing the screen is to make the display clearer and more attractive 
in case you are printing your report to the console instead of the 
printer. Once the report is finished being displayed at the terminal 
screen, the LogiCalc array will be redisplayed just as it was before 
executing the Print command. 

If the report you are printing out is wider than the printing 
width specified above LogiCalc will automatically divide your report 
into segments. The system will fit as many columns across the width of 
the paper that it can given the printing width you entered and then 
will jump down to the next page and print the next segment. This will 
make it very easy to paste together the segments of a wide report. It 
also saves you from having to execute the Print comand several times. 
If the printing in segments is needed, the system will display a 
message informing you that the report is being printed in segments. 
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There will also be a message at the top of the page reminding 
you to make sure the printer is hooked up and there is enough paper 
for the report. We all know how maddening it is to start printing a 
beautiful report, only to find out we forgot to put paper in the 
printer. 

Aft._ 
displayed: 



er . 

After entering the printing width, the prompt shown below will 
ayed: 



be 



Report Printing.. 

Make sure printer and paper are ready 

Printing in segments 

title> 



If you would like your report to have a title, you may now enter 
the first line of the title. Once you have entered the first line of 
the title and hit <CR>, the prompt for title will repeat itself so 
that you may include a second line to your title. In fact, you will be 
able to enter as many lines to your title as you wish. When you are 
finished with the title, hit only the <CR> key to answer the title 
prompt. This will tell the system you are finished with the title and 
will bring the next prompt. Your title will be automatically centered 
at the top of your report. 

If you would prefer not to have a title on your report, enter 
<CR> to the first title prompt. 

If you decide you would rather not print out the report or find 
that you have made a mistake and would like to go back and execute the 
Print command again, you may hit the <esc> key in order to abort the 
Print operation. 

For our first printout, let's give our file a two line title. For 
the first line of the title, enter 'EXAMPLE INVENTORY FILE' as shown 
below: 



Report Printing.. 

Make sure printer and paper are ready 

Printing in segments 

title > EXAMPLE INVENTORY FILE 
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After the above entry is made, the prompt for title will be 
repeated so that we may enter the second line of our title. For the 
second line of our title, enter 'PRINTOUT #1' as illustrated below: 



Report Printing.. 

Make sure printer and paper are ready 

Printing in segments 

title> PRINTOUT #1 



The third time the title prompt is displayed, you may hit <CR> 
and your report will be printed out. 

If you specified earlier that you would like the printing to stop 
after each page is printed, you will need to hit <space> in order for 
the next page to be printed. This will continue until the printing is 
finished. 

After the printing is finished, control will return to the edit 
line. You will now have a complete printout of your inventory report. 
Congratulations I 

The printout is shown on the following pages. Notice that if the 
report is printed in segments the row numbers are included beginning 
from the second page in order to make it easier to line up the report 
once you are ready to tape or paste the report together . 



Page 75 



EXAMPLE INVENTORY FILE 







EXAMPLE 


INVENTORY 


FILE 








PRINTOUT III 






PART # 


PART NAME 


SUPPLIER » 


SUPPLIER NAME 


, PRICE 


12345 


1/4 "BOLT 




35 


ACME 


0.02 


12346 


3/3" BOLT 




35 


ACME 


0.03 


12347 


1/2" BOLT 




35 


ACME 


0.04 


12343 


5/3" BOLT 




33 


UNIVERSAL 


0.06 


12349 


3/4" BOLT 




33 


UNIVERSAL 


0.10 


12350 


7/8" BOLT 




S3 


UNIVERSAL 


0.15 


12351 


1" BOLT 




33 


UNIVERSAL 


0.22 


12353 


t 1/4" BOLT 




35 


ACME 


0.23 



BOLTS 



11 


COST 


PROFIT/UNIT 


•/.PROFIT 


2« — 
31 














41 


0.017 


0.003 


15.00 


51 


0.025 


0.005 


16.66 


6< 


0.038 


0.007 


15.55 


7t 


0.057 


O.OIO 


15.55 


81 


0.086 


0.015 


15.06 


91 


0.129 


0.022 


15.06 


lOt 


0.193 


0.034 


15.23 


111 


0.233 


0.042 


15.00 


12t 








131 









QUANTITY STOCKED 



5000 
5000 
5000 
5000 
5000 
5000 
5000 
500O 

40000 



It 

2» 

31 

41 

51 

6t 

71 

8t 

91 

lOt 

111 

12< 

131 



QUANTITY ON HAND 



HAND 


QUANTITY 


ORDERED 


COST /ORDER 


2120 




2SS0 


48.96 


2900 




2100 


52.50 


3780 




1220 


46.36 


3110 




1390 


107.73 


4195 




305 


69.23 


3063 




1937 


249.37 


1918 




3082 


594.32 







5000 


119O.0O 


!1086 




13914 


2359.47 
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11.27 THE PRINT COMMAND (PARTIAL FILE) 

In this section we would like to demonstrate how to print out a 
subsection of the file. For example, imagine you were asked to produce 
a printout that contained only the part names, supplier # and supplier 
name for the 5/8", 3/4", and 7/8" bolts. If LogiCalc did not allow you 
so much flexibility with the Print command, then we would either have 
to cut up a printout that contained all the information for all the 
bolts or write a new report. However, with LogiCalc, we may printout 
any subsection of the file. 

To begin, access the Print command as we did before. The steps 
are: 

computer prompt your response explanation 



edit ; access command directory 

Command P access Print command 

To which file? PRINTER <CR> send report to printer 

One possibility which can be very useful is to print a subsection 
of the report to a file on the disk where it is stored in ASCII code 
and is therefore available for use in a word processing environment. 
For instance, if you would like to use part of the report in a letter, 
then write that section to a file and it may then be included as an 
insert file in another printing program. For now, we will generate a 
standard printout. 

The prompt that will now be displayed is shown below: 



top left corner of form: Al 



In this example, we wish to print out only the information for 
three bolts beginning with the part name - we are not interested in 
the part # which is the upper left corner of the file. So, instead of 
typing <CR>, we should enter •B7*. This will insure that rows 1 
through 6 and column A are excluded from the printout. Your response 
for this prompt is shown on the next page: 



Page 7 7 



top left corner of form: B7 



The next prompt will ask: 



bottom right corner: L13 



In this printout, we are only interested in the information 
contained in the columns for part name, supplier # and supplier name 
for the three bolts mentioned, so column D would be the last column. 
The 7/8" bolt is the last one we want included, so the last row is row 
9. Consequently, the bottom right corner of this printout should be 
D9. 'LIS* is the current cursor location, so it is the default value 
for this prompt. To override the default, enter 'D9' as illustrated 
below: 



bottom right corner: D9 



The next prompt to be displayed is: 



form length: CONTINUOUS 



We are only printing a small portion of the array, so we really 
need not be concerned too much with this prompt since the printout 
will not be more than one page. As a result, hit the <CR> key to 
observe how nothing is entered on the prompt line, but the prompt is 
replaced by the next prompt. This means the system answered the prompt 
by default. In other words, by not entering anything before the <CR> 
key is hit, the system interprets your response to mean you would like 
the printing to be continuous from page to page. The next prompt will 
ask: 



Page 78 



printer width: 132 



As in the previous example in section 11.26, we will specify the 
printer width to be 80 to insure there will not be any trouble with 
any print size or paper size and you will get your desired printout. 
Enter '80' as shown below: 



printer width: 80 



As mentioned in the previous section, after the above prompt is 
answered the screen will be cleared of its present display and will 
then present the last few prompts. The screen is cleared so that in 
case the report is being sent to the console, it will be easier to 
view the report than if the LogiCalc array was not first cleared. 

If the subsection of the report you are printing out is larger 
than the printing width entered above the portion of the report you 
are printing will be divided into segments and you will see the same 
message as mentioned in the previous section on printing an entire 
report. Since the subsection of the report we are printing is smaller 
than the printing width, we will see the following prompt instead: 



fix ordinates (y,n)? 



This prompt is asking you whether you would like to include the 
column and row headings on your printout. This would be helpful to us 
in this example since we are only printing out a subsection of the 
file. Otherwise, we will not necessarily know what some of the numbers 
and text pertain to. If we were to answer 'N' to this prompt and 
thereby not include the column and row headings, our printout would 
appear like the following: 
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5/8" BOLT 
3/4" BOLT 
7/8" BOLT 



83 


UNIVERSAL 


83 


UNIVERSAL 


83 


UNIVERSAL 



If we decide to include the ordinates by entering 'Y' to the 
prompt above, the printout will resemble the following: 



PART NAME SUPPLIER # SUPPLIER NAME 



5/8" BOLT 
3/4" BOLT 
7/8" BOLT 



83 
83 
83 



UNIVERSAL 
UNIVERSAL 
UNIVERSAL 



There are no row headings in our EXAMPLE file, but the column 
headings are included as shown. 

In order to give our printout clarity, enter 'Y' so that the 
headings are included. Your response will appear as shown below: 



fix coordinates (y,n)? Y 



After the above prompt is answered, the next prompt will 



say: 



Report Printing.. 

Make sure printer and paper are ready 

. title> 
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We may include as many lines to our title as we wish. To answer 
this prompt we should enter in what we would like to be on the first 
title line. When we hit <CR>, the prompt will repeat and we may then 
enter in what we would like for the second line of the title. So, each 
time the prompt appears, it will be another line of title. When you 
have as many lines of title as you wish, answer the prompt by only 
hitting the <CR> key. For our first title line, enter 'EXAMPLE 
INVENTORY FILE SUBSECTION' as shown below and then hit <CR> . 



Report Printing.. 

Make sure printer and paper are ready 

title> EXAMPLE INVENTORY FILE SUBSECTION 



For the second title line, enter 'PRINTOUT #2' and then 
hit <CR>. 



Report Printing.. 

Make sure printer and paper are ready 

title> PRINTOUT #2 



The next time the title prompt is repeated, do not enter anything 
before hitting <CR> . Now, the printing will begin. 

After the printing is completed, control will be returned to the 
edit line. 

You should now have your second printout and hopefully feel 
comfortable in knowing how to use the Print command to your best 
advantage . 

The resulting report is shown below. 



EXAMPLE INVENTORY FILE SUBJECTION 
PRINTOUT #2 



PART # 


PART 


NAME 


SUPPLIER # 


SUPPLIER NAr.c 


1234S 


5/S" 


BOLT 


33 


UNIVERSAL 


12349 


3/4" 


BOLT 


S3 


UNIVERSAL 


12350 


7/3" 


BOLT 


33 


UNIVERSAL 
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11.28 THE /PAGE FUNCTION 

There is another function which can be used in conjunction with 
the Print command. The /Page function serves as a form feed 
instruction to the system during the Print operation. When the system 
encounters the row with the /Page entry, the printing will skip the 
rest of the present page and will resume printing on the top of the 
next page . At present, the /Page entry must be located in column A. 

For example, if you would like to print the first four columns 
from our EXAMPLE file, but, you would like to have rows 1 through 6 on 
one page and rows 7 through 13 on another page, then you could insert 
a row at row 7 and enter '/p' (now doesn't that shorthand notation 
save you a lot of hard work?) at A7. Now specify your bottom right 
corner as D14 and proceed through the rest of the Print command as 
before. The resultant printout will show columns 1 through 6 on the 
first page and rows 8 through 14 on the second page . 



11.29 LINEAR REGRESSION (FORECASTING) 

If you could choose what you would like most in a financial 
report modeling system, what would it be? Most likely it would be the 
ability to tell the future. After all, one of the most important goals 
of a financial report writing system is to give the best advice it 
can, based on past data. Well, SPI has taken this goal to heart and 
LogiCalc incorporates the ability to compute a linear regression which 
computes the best estimator of a predicted value based on a given 
value or computes the best estimator of the necessary given value by 
entering a hypothetical predicted value. For example, you may enter 
values for the amount of sales for six periods and the amount of money 
spent on advertising for the same period. Now, by using the regression 
command, you can compute a linear equation which will best fit the 
data entered. Using this equation, you may then enter a given amount 
of advertising money and the system will compute the best predicted 
value for the amount of sales you will have in that month based on the 
past correlation of advertising expense and amount of sales. You will 
also be able to enter in the amount of sales you want and compute the 
best estimator of the amount of money you will need to spend in 
advertising to reach that sales level based on the past data entered. 

As you can imagine, this feature will open all kinds of 
forecasting possibilities. The linear regression is much more 
efficient that a simple growth assumption. Everyone interested in a 
financial modeling system will be able to benefit from this feature. 

In order to demonstrate the regression feature we will leave our 
inventory example behind us and create a new example. One useful 
application would be the situation mentioned above. We may enter data 
for money spent on advertising, dollar amounts of sales, and some of 
the months of the year to illustrate how to best forecast future 
trends based on a linear regression of past data. 
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To begin, insure yourself that your EXAMPLE file is saved 
then type the following in order to clear the LogiCalc array. 



and 



computer prompt 



your response 



explanation 



edit 

Command 

Delete: A) 11 R)ow 
C)olumn E)ntry 

Verify Y/N - 



D 



access command directory 
access Delete command 



delete contents of entire 
array 

after making sure you have 
saved your work, enter 'Y' 
complete deletion. If you 
have not saved your work and 
want to preserve it, enter *N' 



Now the contents of the LogiCalc array will be erased and you may 
begin to work on a new project. We may begin our new example by 
entering text and numeric data for the first six months of 1982. For 
simplicity, we will present diagrams illustrating what your screen 
should resemble after entering the appropriate data. This will be a 
good time to review all the commands you have learned up to this 
point. Shown below is a replication of your screen with location Al as 
the upper left hand corner. 
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**** ie ****** **ie ***************** ii***1t******ie*ie*ic*********ie** it ***ie** 
* 

* Col> A B C D E : 

* 



Row+ 

1:> 
2: 
3: 

4:district A 
5: product 1 
6: product 2 
7: 

8: advertising $$ 
9: 
10: 



JAN 
1 



300 
100 

1230 



FEB 
2 



435 
92 

1300 



MAR 
3 



650 
81 

1435 



APRIL 
4 



875 
64 

1450 



* 
* 

* current:: 

* data : : 
* 

* 
* 



cursor: Al 



current: Al 



type: 

contents : 

edit: 



♦Commands :'@', •^•,'?', <new data> , <arrows> , <ETX> , <TAB> , <CR> , ' ; ' commands : * 
*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?) storage W)hat =)lock * 
* * 

************************************************************************* 



If you move the cursor so that location Fl is the upper left hand 
corner, you may enter the following data and your screen will appear 
as shown on the next page: 
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******************************************************************* 

* * 

* Col> F G H I : * 



Row+- 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 



MAY< 
5 



JUNE 
6 



1200 
55 

1510 



1440 
47 

1530 



* 
* 

* current:: 

* data : : 
* 

* 

* 



cursor: Fl 



current: Fl 

type: text; center justified 
contents : ' MAY * 
edit: 



* Commands: '@', '"','?', <new data>, <arrows>, <ETX>, <TAB>, <CR>, ' ; 'commands:* 
*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?) storage W)hat =)lock * 

* * 
************************************************************************* 



Now we have a potential situation with which to work. With the 
information given we may now use the regression function to compute a 
linear equation which may then be used to compute the best linear 
estimators of values we wish to forecast. The regression function 
allows you to enter one range of entry locations followed by a comma 
followed by the first coordinate of the second range of entries. The 
number of entries within each range must be the same and that is why 
you only need to enter the first coordinate of the second range. The 
values contained within the first range of entries are the values for 
your independent variable. Independent variable is a statistical term 
which basically means that the value of the variable is determined 
independently from the values of other variables. 

In contrast, the second range of entries contain the values for 
your dependent variable. The dependent variable is the one which you 
are assuming is influenced by other factors besides itself. To clarify 
all this, in one of the examples in this section we will assume the 
amount of sales to be dependent on the amount of money spent on 
advertising. In this case, the money spent on advertising will be our 
independent variable and the amount of sales will be our dependent 
variable. Most likely, in the real world, sales will not be completely 
determined by the amount of advertising we do, but we can get a pretty 
good idea of how sales have correlated with advertising expense. 
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For our SALES example file we will enter the regression function 
in three different places in order to demonstrate some slightly 
different points. For example #1, at location H5 enter 

'+regr(B2>G2,B5) ' . 

The plus sign insures the entry is interpreted as numeric. The ' regr ' 
signifies the regression function. 'B2>G2' is the range of entries 
which contain the values for the independent variable. * B5 ' is the 
beginning of the range of entries which contain the values for the 
dependent variable. The system will automatically know to include the 
entries through G5 since that will result in the same number of 
entries as the range for the independent variable. So, in this first 
equation we are regressing the amount of sales on the time periods 
(months). This will allow us to see how sales are doing as time passes 
by and then we will be able to come up with a forecast for sales in 
any future time period based on the trend established with this data. 
A numerical value will be displayed at location H5 where you entered 
the regression function. We will explain this value in a minute. 

With one regression function entered and with location Fl as the 
upper left hand corner, your screen will simulate the following 
illustration: 
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* * 

* Col> F G H I : * 



Row+- 

1 

2 
3 
4 
5 
6 
7 
8 
9 
10 



MAY< 
5 



JUNE 
6 



1200 
55 

1510 



1440 
47 

1530 



816.66 



* 

* current : : 

* data : : 
* 

* 

* 



cursor: Fl 



current: Fl 

type: text; center justified 
contents: 'MAY' 
edit: 



* Commands: '(§','"','?• , <new data> ,< arrows > , <ETX>, <TAB>, <CR>, ' ; 'commands:* 
*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?) storage W)hat =)lock * 

* * 

************************************************************** 



The numerical value you see represents the mean or average value 
for the range of dependent values given in the regression function. 
Sometimes, this value may be useful to you to know for other 
calculations, so the regression function returns this value. If you do 
not think you have any need for this value, there is a simple way to 
keep the regression function but have it return a blank value into the 
array. For instance, move the cursor to location H5 and enter 



+regr(B2>G2,B5): ' ' : ' • 



The outer quotation marks showing what to enter have been omitted to 
avoid confusion. This expression will return a blank value in any 
event. You may go ahead and enter this formula as we will not need to 
use the mean of the dependent range so we might as well leave the 
screen as uncluttered as possible. 

The regression function, which computes a linear equation from 
the two ranges you have entered, is the first of two steps to 
forecasting with LogiCalc. Once you have used the regression function, 
you have a choice of three other functions to use in conjunction with 
the regression function. These three functions include the following: 
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1. proj - allows you to enter a value for an independent 

variable and then tlie best estimate for the 
dependent variable will be calculated and entered 
into the current cursor location. 

2. depd - allows you to enter a value for the dependent 

variable and then the best estimate for the 
independent variable is calculated and entered 
into the current cursor location. 

3. slope - allows you to have the system enter the slope 

of the linear equation computed from the regression 
function, into the current cursor location. The 
slope gives you a rough estimate of the correlation 
between the independent variable and the dependent 
variable. If the slope is 30 it means that for a 
change of 1 in the independent variable, you will 
get a change 30 times that size in the dependent 
variable. If the slope is -20, it means that for 
an increase of 1 in the independent variable, you 
will get a decrease of 20 in the dependent variable. 
As an example, this information can tell you if, 
as advertising expenses increase, there is a 
simultaneous increase or decrease in sales and 
how large the change is. NOTE: this type of 
regression does not pretend to determine cause 
and effect, but only tells you what kind of 
correlation there is. 

We shall demonstrate all three of these functions within this 
section. 

Let us say we would like to estimate how much sales for product 1 
will be in October given the data for the first six months of this 
year. To calculate our best estimate, move the cursor to location 15 
and enter '+proj(10)'. We know from our regression function that the 
month number is the independent variable and the sales amount is the 
dependent variable. With the project function, we enter a known amount 
for the independent variable and the system returns the best estimate 
for the dependent variable. In this case, the system returned the 
amount of '2343.23'. This informs us that based on the first six 
months of this year, we can expect to have sales of $2343.23 in 
October of this year for product 1. 

At location H6, enter '+regr (B2>G2,B6 ) ' . This is very similar to 
what you entered in the first example. The reason why we have included 
the regression for this location also is to contrast results with the 
first example. In example #1 there is a positive relationship between 
sales and time. That means, as time is increasing, sales are also 
increasing. In example #2, however, as time is increasing, the data 
shows sales to be decreasing. This will show how regression can be 
used for both positive and negative trends. 
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Once your regression function has been entered, move the cursor 
to location 16 and type '+proj(10)'. The result of '.18' tells us that 
by October sales will have declined so much on this product as to be 
next to nothing. If we were to enter '11' or '12* the amount would be 
below zero informing us that we were building up unwanted inventory. 

For the last example, go to location H8 and type 
'+regr (B8>G8,B5) ' . This example is the one we mentioned above where 
amount of money spent on advertising is the independent variable and 
sales of the first product is the dependent variable. Note that this 
regression function has the same mean for the dependent range as the 
first example. This is because it has the same range of entries for 
the dependent variable . You may enter the equation to return a blank 
entry with the regression function, if you would like. 

This time we will demonstrate the dependent function. Move the 
cursor to location 18 and type •+depd(2000 ) ' . This is asking for the 
best estimate of the amount of money you need to spend on advertising 
to result in a sales amount of $2000. If you were to enter 
+proj(2000), that would be asking for the amount of sales WITH 
advertising expenses of $2000. See the difference? You are telling the 
system, "I want a sales level of $2,000. How much money will I need to 
spend on advertising in order to reach that level, based on the data 
for the first six months of this year." 

The result shown on the screen indicates that we will need to 
spend $1750.88 on advertising to reach a sales level of $2,000 for 
product 1. Just to prove to yourself that these are not random 
numbers, now type ' +proj (1750.88) ' . This is proposing the reverse. If 
we spend $1750.88 on advertising, what will the best estimate of sales 
be. The result is $1999.98 and if you use the format command to extend 
the decimal precision the result will be even closer to $2000 which 
is, of course, what the sales level should be, given our first 
prediction. See what fun things you can do? 

The last function to demonstrate is the slope function. Move the 
cursor to location J5 and enter '+slope()'. Now go to location J6 and 
enter the same thing and repeat this procedure at location J8. In all 
three entries the result will be '3.46*. If you doubt that this is 
really the case, then you are absolutely right. LogiCalc has been set 
up so all of the functions which work with the regression function, 
work with the last regression function entered in time sequence. Since 
the regression function at location H8 was the last one we entered, 
the system thinks we are asking for the slope of that regression 
equation three times (15, 16, and 18). This brings up a very important 
point: If you want to enter a function to be used with a regression 
function that was not the last regression function entered, then 
execute the recalculate command (';R', 'A') afterward in order to get 
the correct result. For instance, since we want the slope for all 
three of the regression functions, we should execute the recalculate 
command to insure they are evaluated properly. 
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Once the recalculate command has been executed, and labels for 
the month of October have been entered, your screen will resemble the 
diagram below if location Gl is the upper left hand corner. 



********************************************************************* 
* 

* Col> G H I J : 

* Row+ 

* 

* 

* 

* 

* 

* 

* 

* 

* 

* 



1 
2 
3 
4 
5 
6 
7 
8 
9 
10 



JUNE< 
6 



1440 
47 

1530 





OCT 




10 




2343.23 


73.16 


.18 


816.66 


1999.98 



234.85 
-11.22 

3.46 



+ 



cursor: Gl 



current: : 
data : : 



current: Gl 

type: text; center justified 
contents : ' JUNE ' 
edit: 



♦Commands :'@', '^','?', <new data> , <arrows> , <ETX> , <TAB> , <CR> , ' ; ' commands : 

*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed} 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?) storage W)hat =)lock 
* 

************************************************************************ 



Note the mean for the dependent range for the first regression 
function we entered has been replaced by the blank entry, yet we may 
still use the regression function stored at that entry. Now we have 
the slopes for the three regression functions we entered and yoii can 
get a rough estimate of the correlation between the values regressed 
against each other. For example, the second regression function 
results in a slope of -11.22. This informs us that sales are 
decreasing about 11 units on the average as each month passes by. 

A good rule of thumb is to execute a recalculate command for each 
time you use a project, dependent, or slope function unless you enter 
the regression function to be used with it immediately previous to 
entering the project, dependent, or slope function. Another very 
important rule to remember to insure correctness is to have your 
slope, dependent, and/or project function after the regression 
function which it uses but before the next regression function. By 
"after" we mean to the right of it if it is on the same line or on a 
line below the regression function otherwise. By "before the next 
regression function" we mean to the left of it if it is on the same 
line and on a line above the regression function otherwise. This is 
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because the recalculate command proceeds in a left to right order from 
the top to the bottom of the array. By having your project, dependent, 
and slope function after the regression function but before the next 
one you insure that it is evaluated according to the proper regression 
function. The best advice is to locate your slope, dependent, and/or 
project functions in the locations immediately to the right of the 
regression function. This only makes sense anyway since the regression 
function will almost always be used in conjunction with one or more of 
the other three functions . 

In our discussion of our SALES example, we have ignored one 
possible complication. For some businesses, seasonal effects pose a 
problem to linear regression. In a case like this, rather than perform 
a regression on all the months of one year, you could use the data for 
the same month over the last few years and perform a regression on 
this data. 

We hope the linear regression capability of LogiCalc will prove 
to be extremely useful to you. Linear regression can be a very 
valuable tool in assisting you to recognize trends based on past data 
and thus helping you to make some educated guesses about the future. 
Linear regression does not prove a cause and effect relationaship, but 
it does give an indication of how changes in one area will correlate 
with changes in another area and this in itself may be enough. Used as 
an aid, regression will help you in any type of forecasting you would 
like to perform. 



11.30 THE LOAD COMMAND 

The Load command is utilized to reload files into the LogiCalc 
main menu. To demonstrate the Load command, we will first clear the 
screen of our SALES file and then reload EXAMPLE back into the 
LogiCalc array. Make sure you have saved SALES and then follow these 
steps to clear the screen. Note that it is not required that you clear 
the screen before loading a new file, we are doing it here only for 
clarity of instruction. 



computer prompt 



your response 



explanation 



edit 
command 



D 



access command directory 
access Delete command 



Delete: A) 11 R)ow 
C ) olumn E ) ntry 

Verify Y/N 



A 
Y 



clear the screen 

insures this is ok with you 
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To execute the Load command and regain access to our EXAMPLE 
file, duplicate the following steps. 



computer prompt 



your response 



explanation 



edit 

Command 

filename 

load position: Al 



L 
EXAMPLE 

<CR> 



access command directory 

access Load command 

reload file named 
EXAMPLE 

load EXAMPLE into the 
array with the upper left 
hand corner of the report 
at location Al 



The result will be that our file is loaded into LogiCalc and 
appears exactly as it did before we deleted it from the screen. 

The last prompt asking the load position grants us the option of 
loading the file into the LogiCalc array with the upper left hand 
corner at any position we would like - providing there is enough room. 
The "Al" following the prompt does not mean that location Al is the 
only place we can load in the report. Instead, it lets us know that 
the default loading position is location Al. The default load position 
is the leftmost entry in the top row of the model at the time the 
model was saved. In this case, the first entry was located Al when we 
saved the model, so Al now appears as the default load position. So, 
if we would like the upper left hand corner of the report to be 
positioned at Al, then type <CR> . 

If we would like to load the report at another location, enter 
the coordinate for the location or move the cursor to the location you 
would like to have as the upper left hand corner and type the *@^ 
symbol. For example, type ';L' to access the Load command again and 
then type 'EXAMPLE'; but, this time, enter 'B3' as the load position. 
Your screen will now resemble the following: 
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PART # 



PART NAME SUPPLIER # 



********************************************************** 

* * 

* * 

* Col>A BCD: * 

* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 



Row+- 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 



12345 
12346 
12347 
12348 
12349 



1/4" BOLT 

3/8" BOLT 

1/2" BOLT 

5/8" BOLT 

3/4" BOLT 



35 
35 
35 
83 
83 



C EXAMPLE] cursor: Al 

current: : 
data : : 



current: Al 



type: 

contents : 

edit: 



* 
* 
* 
* 
* 
* 
* 
* 
* 
* 

* 

* 
* 
* 
* 
* 
* 

* Commands :'@', '"','?', <new data> , <arrows> , <ETX> , <TAB> , <CR> , ' ; ' commands : * 
*{H)elp R)ecalc F)ormat S)ave L)oad C)opy D)elete M)erge A)uto T)ext ed}* 

*{Q)uit G)oto I)nsert P)rint E)dge 0)rder ?) storage W)hat =)lock * 

* * 

************************************************************************* 

This ability to alter the load position can be very useful, 
especially in conjunction with the Merge command. It now becomes 
possible to construct reports and models in modules and then mix and 
match them on the screen to put together all kinds of useful 
variations. For instance, you could construct a check writing module 
in one file and a payroll file in another module and then combine the 
two to make payday a lot less work. 

One point to keep in mind is the file that you are Merging onto 
the LogiCalc array will override the existing file if entries in both 
files have the same coordinate address. So, once again, we recommend 
that you save the file before merging on a new file, if you have made 
any changes since loading it into the LogiCalc array. 



11.31 THE EXTENDED SCREEN COMMAND 

At times, you will probably find that it would be very convenient 
if you could get a look at the entire array. However, we are limited 
by the size of the screen on your computer. Most screens will display 
22 lines and either 40 or 80 columns. We have attempted to maximize 
the space by giving you all the information on the screen you will 
need and, at the same time, allowing you to see a fairly large portion 
of the array. We have included an option which will allow you to 
change the screen display according to your needs. 
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The extended screen command allows you to switch to an alternate 
screen mask which will display 15 rows of the LogiCalc array rather 
than the standard 10- When the extended screen command is implemented, 
the bottom section of the screen which lists the commands is replaced 
and the array is extended to 15 rows. 

If our screen has the same display it did in the previous 
diagram, then we can now execute the extended screen command to show 
you what the new result would be. Here are the steps to executing the 
extended screen command: 



computer prompt 



your response 



explanation 



edit 
Command 



access command directory 

access extended screen 
command 



Your screen will now simulate the following diagram: 



* 

* Col>A B C D : 



Row+- 

1 

2 

3 

4 

5 

6 

7 

8 

9 
10 
11 
12 
13 
14 
15 



PART # 


PART 


NAME 


SUPPLIER # 


12345 


1/4" 


BOLT 


35 


12346 


3/8" 


BOLT 


35 


12347 


1/2" 


BOLT 


35 


12348 


5/8" 


BOLT 


83 


12349 


3/4" 


BOLT 


83 


12350 


7/8" 


BOLT 


83 


12351 


1" 


BOLT 


83 


12353 


1 1/4" 


BOLT 


35 



[ EXAMPLE] cursor: Al 



current: Al 



current: : 
data : : 

LOGICALC - 



type : 
contents : 
edit: 
(c) 1981 Software Products Intl. 



Vers. E.05FP jdk 



ic**icic*ie1«***it**1c**ic*icicic***icic****ic*ic***icicic**ie**ic*ie******ieieic**ie***ific******it* 
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As a result of the extended screen command, you will be able to 
view 5 more rows of the LogiCalc array. This will prove to be very 
convenient at times instead of being forced to move the cursor to 
change the screen display to another section of the array. Anytime you 
would like to return to the standard display to reference the command 
list or for whatever reason, type the same ';*' command and the usual 
10 row display will return. 



11.32 THE QUIT COMMAND 

There are still a few commands which we have not demonstrated. 
The Quit, Help, and Version commands may be utilized at any time you 
are working on LogiCalc and so we have included them at the end of the 
Operations section for easy reference. 

The Quit command is used for quitting the LogiCalc program. When 
you are finished working with LogiCalc, then save your file if you 
would like to have a record of it for later use. After the file is 
saved, you may execute the following steps to quit the program. 



computer prompt your response explanation 



edit ; access command directory 

Command Q access Quit command 

Verify Y/N- 'Y* or 'N' see below 



If you enter *N' to the prompt to verify quitting the LogiCalc 
program, the Quit command will be aborted and control will be returned 
to the edit line. If you answer 'Y' to the above prompt, LogiCalc will 
now be aborted and the CP/M A> prompt will appear. 



11.33 THE HELP COMMAND 

The Help command serves as a very convenient and useful directory 
to the functions of the various operations available with LogiCalc. 
There is also a lot of useful information and reminders in case you 
have any trouble entering different data values. 
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The Help command is more convenient to use than this manual in 
case you just need a quick reminder about a certain point, but if you 
need more than a quick reminder this manual will probably help refresh 
your memory. 

To execute the Help command, follow these steps: 

computer prompt your response explanation 

edit ; access command directory 

Command H access Help command 

After the preceeding steps are executed, the following screen 
display will occur; 

************************************ ******* ****************************** 

* * 

* Help page 1 hit <enter> to continue * 

* * 

* Main entry mode ^ __«_______ * 

* Move the cursor using the arrows, <ENTER>, and <ETX> . Enter, if nothing* 
*has been typed, moves to the next entry position. <ETX> goes to the * 
*start of the next line. * 

* Enter data by typing the information you wish in the location (if the * 

*'type' indicator is wrong, the '^'key will switch it) then hit <enter>* 

* * 

* * 

♦SPECIAL FUNCTIONS: * 

* <TAB> = ;goto. '?' = evaluate input as equation. <ESC> is delete line.* 

* TEXT ENTRY: in the 1st 2 chars of line use: * 

* '/r' to right justify text in line,'/l' to left justify and '/c' to* 

* center. '/=' duplicates the string across the whole column. * 

* DATA ENTRY: once at least 1 char has been typed, the cursor may be * 

* pointed at other positions? the '(§' key enters the cursor position * 

* into the current entry. A data item may be entered as an equation * 

* {if there is a position entry (for ex. AZ12) the equation may be * 

* re-evaluated to reflect changes in the addressed data.} * 

* FUNCTION FORMAT: name (position, position>position, ( expression) , etc . ) * 

* value given to function is sum of arguments * 

* Functions available for math: * 

* sum, avg, cnt, max, min, regr, proj, depd, slope * 

* * 

************************************************************************* 
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After the first page of the Help directory you will need to hit 
the <CR> key in order to present the following page: 

************************************************************** 



* 

* Help page 2 Hit <enter> to continue 

* Extended commands 

* 



* these commands are accessed by hitting the ' ; ' key 
* 



* Auto 

* Copy 

* Delete 

* Edge 



enter automatic entry mode.<ESC> will abort 

copy a (range) entry to another (range) entry 

Delete a row, column, entry or the whole array 

set the window top left corner to the cursor position 

change column size or precision under cursor 

move the cursor to a specific column 

prints this information 

Insert a row or column into the array 

Load a file into the array 

overlay file onto array 

change the evaluation (column/row) order of the array 

Print a report 

exit the report generator 

* Recalculate recompute entry at cursor or whole array in current order 

* Save Save the array to a file 

* What if text, prints 1st column & row entries of cursor position 

* Text edit entry or input data 

* ? space available * switch display size = set/clear locked screen* 

* I* 

************************************************************************* 



* Format 

* Goto 

* Help 

* Insert 

* Load 

* Merge 

* Order 

* Print 

* Quit 



After you hit the <CR> key for the last page of the Help directory, 
the Help directory will be replaced by the main menu just as you left 
it and control will be returned to the edit line. 



11.34 PROGRAM LCDUMP 

With LogiCalc we have included a separate, but very helpful 
secondary program called "Icdump". This support program allows you to 
print out a listing of the contents of the LogiCalc array. That means 
you may have a printed copy of all the formulas and specifications 
that are behind the scenes to create your nice report which only 
includes calculated results. Lcdump prints out each coordinate that 
has a data entry and informs you of the column width, type of entry 
(including justification if the entry is text) and the contents of the 
entry. 
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The importance of Icdump is the ability to print out the contents 
of the report in order to be able to store it in a safe place. In the 
case of a disk being ruined or lost or someone removing your report 
file, you still have a copy of your hard work. 

Let's take a minute to demonstrate the use of Icdump so you will 
know how to obtain permanent copies of your report contents. To begin, 
you must exit the LogiCalc program (use the Quit command, but make 
sure you save your file first -if you have not done so) . 

Key in the CP/M command; 



A>LCDUMP <RETURN> 



Now a prompt will ask: 



* * 

* Report Dump 1.0 * 

* Output file: * 

* * 

*************************************************************** 



You are now being asked to enter the destination of where you would 
like your file to be printed. Most of the time, you would like your 
report to be sent to the printer in which case you may enter the 
volume name or number of the printer (e.g. "#6:" or "printer:"). If it 
happens you would like your report to be written to another file on 
the disk, enter the name of the file you would like it to be stored 
un^er. The following prompt will ask: 



************************************************************************* 

* * 

* Report Dump 1.0 * 

* Output file: printer: * 

* LogiCalc file name: * 

* * 

************************************************************************* 



Here, you may enter the name of the file under which your report 
is stored. This will be the name you specified when you saved the 
report using the Save command. If you enter the name of a file which 
does not exist or an incorrect name, the system will tell you the file 
was not found and will give you another chance to enter a file name. 
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For our demonstration we will print out the contents of the file 
BALSHEET which we introduced in section II. 3. So, enter 'BALSHEET' to 
bring the next prompt which will ask: 

***** it* ***************************** ie ************* it 1eicicic***ie*1c*ie** 

* * 

* Report Dump 1.0 * 

* Output file: printer: * 

* LogiCalc file name: BALSHEET * 

* Comments? * 

* * 

************************************************************************* 



Before you answer this prompt, it is important to make sure the 
printer is connected and ready to go because once this prompt is 
entered the printing will begin. If you would like to include a one 
line title to the printout, enter it to answer this prompt. If you do 
not need a title hit the <CR> key and the printing will begin. For our 
demonstration we do not really need a title, so hit the <CR> key. When 
the printing is complete, there will be another prompt asking: 



************************************************************************it 
* 

* Report Dump 1 . 

* Output file: printer: 

* LogiCalc file name: BALSHEET 

* Comments? 

* Print another file? 
* 

************************************************************************ 



If you would like to print another file's contents, enter 'Y* and 
the sequence of steps you have just completed will be repeated for 
another file. If this printout was the last one you needed, enter 'N' . 

For our demonstration, enter 'N' since we will not need to repeat 
the demonstration. You may take a look at the replication of the 
printout that resulted from printing out the contents of our balance 
sheet file. The sample printout- replication is on the following page. 
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RG File balsheet 



Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Pofci 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 
Posi 



t ion 
tion 
t i o n 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tion 
tioa 



Bl 
A4 

A5 

A6 
B6 
A7 
B7 
B8 
A9 
C9 
Cll 
Ai2 
'C3 2 
CI 3 
A14 
D14 
D15 
B20 
A23 
A24 
B24 
A25 
B25 
B26 
A27 
C27 
C29 
A30 
C30 
A33 
A34 
B34 
A35 
B35 
Bolo 
A37 
C37 
C39 
A40 
C40 
A42 
D42 
D43 



Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 

Width 



20 

23 
20 



20 
28 
20 
20 
28 
13 



Type; Text (Centered) : ASSETS 

Type: Text (Centered) s CURRENT ASSETS 

Type: Text <Lel=t justified) :CASH 

Type: Numeric s 3000000 = SOOOOOO. 000000000000 

Type: Text <Lel=t Justified) : ACCOUNTS RECEIVABLE 

Type : Nume r- i c : 1 00000 = 1 00000 . 000000000000 

Type:Text (Left Justified) : INVENTORY 

Ty pe : Nume r i c : 5225SS0 . 3f5 = 5225850 . 350000000000 

Type* Text (Repeating) :~ 

Types Text (Centered) :TOTAL CURRENT ASSETS 

Type: Numeric : •►SUM ( B5>B7 ) - 13325350.350000000000 



13 Type 
28 Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 



13 
13 
28 
13 
13 
20 



2a 
20 
23 
20 
20 
28 



28 
28 
20 
28 
20 
20 
28 
13 
13 
28 



i TOTAL ASSETS 
' 13325350.350000000000 
t - 

.'TOTAL ASSETS 
: i 3325350 , 350000000000 



Text (Repeatins) 

Text ((Centered) 

Nume r- i c : •►SUM ( B5>B7 ) 

Text (Repeating) 

Text (Centered) 

Nume r i ^: s -J-SUiM ( B5>B7 ) 

Text (Repeating) := 

Text (Left Justified) i LIABILITIES ^ EQUITY 

Text (Centered) : CURRENT LIABILITIES 

Text (Left Justified) : ACCOUNTS PAYABLE 

Numeric 5 9850.35 « 9S50 . 350000000000 

Text (Left Justified) : NOTES PAYABLE 

Numeric : 4^ 10000 = 483 0000.000000000000 

Text (Repeating) :- 

Text (Centered) : TOTAL CURRENT LIABILITIES 



13 Type: Numeric s^»-SUM(B24:>B25) - 4819350.350000000000 



13 Type 
28 Type 
13 Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 



13 Type 
28 Type 
13 Type 
13 Type 



Text (Repeating) 

Text (Centered) : TOTAL LIABILITIES 

Nume r i c : •►SUI'i ( B2^>B25 ) - 481 9850 . 350000000000 

Text (Centered) : OWNERSHIP tk EQUITY 

Text (Left Justified) :CAPITOL 

Numer i c : 8500000 « 8500000 . OOOOOOOOOOOO 

Text (Left Justified) : NET INCOME 

Numeric s 6000 » 6000,000000000000 

Text (Repeating) i" 

Text (Centered) i TOTAL WORTH 

Nume r i c s -t-SUM ( B34>B35 ) = 8506000 . OOOOOOOOOOOO 

Text (Repeating) J- 

Text (Centered) : TOTAL OWNERSHIP « EQUITY 

Numeric : •♦•SUM(B34>B35) = 8506000 . OOOOOOOOOOOO 

Text (Left Justified) : TOTAL LIABILITIES ?< EQUITY 

Numeric : ■♦•C30-«-C40 = 13325850.350000000000 

Text (Repeating) :=• 
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11.35 SUMMARY 

We have now concluded our demonstration of all of the functions 
and conunand operations available with LogiCalc. We hope that this 
manual has proven to be a helpful learning guide and will also assist 
you as a handy reference tool. To make this manual as complete as 
possible, we have included four appendices to serve as a fast and easy 
reference source for use with the LogiCalc program. 

As a last reminder, please remember to make a backup of all of 
your important work in case something should happen to your disk or 
your computer . 

We hope you will enjoy using the LogiCalc program and find it a 
valuable asset to your organization. 
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SECTION III 



APPENDICES 



APPENDIX A 



COMPUTER ORIENTATION 



We have included the following section to outline the computer 
needs of LogiCalc. In addition, there is a brief introduction to the 
world of computers for those of you who are exploring for the first 
time. Of particular importance are the suggestions on the proper care 
of the flexible diskettes used in your microcomputer. 



Required Equipment and Capacity 



LogiCalc requires the following operating environment: 



Computer: 



Any that supports CP/M and has at least 
64K memory 



Terminal: 



24*80 

clear screen (opt.): 

clear to end of line/screen 

random cursor addressing 



Printer: 



80 column or larger 



Disk: 



minimum 250k bytes of floppy disk storage 



Operating System: CP/M 
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General Computer Information 



A computer employs four basic operations: input, processing, 
storage, and output. Below is a short summary of what goes on at each 
of these steps. 



Input: 



Input in this context refers to the process involved 
in presenting the computer with data. When a computer 
receives input data, it is said to "read" the data; thus, 
"input" is synonymous with "reading." There exists a 
variety of input devices; however, the one that we are 
interested in is the keyboard, similar to an electric 
typewriter, on which the data is entered by an operator. 
The keyed data is visually represented on the screen of 
your terminal. 

In LogiCalc, input is accomplished through typing informatioi 
at the terminal which is then relayed to the computer. 



Processing: 



The computer is said to be "processing" the data when 
it is manipulating the data (e.g., performing logical 
or arithmetical operations). Processing also refers to 
the input/output functions and internal decisions executed 
by the computer. 

The LogiCalc program instructs your computer as to how to 
manipulate the data you have entered into the terminal . 
For instance, if you enter the commands to add two numbers, 
LogiCalc will instruct the computer as to how to process 
this action. 



Storage: As with anything, storage refers to storing certain 

material . Program content and data are stored in the 
computer's internal memory, but only as long as that 
particular program or data is being processed. The 
diskette is a more permanant storage medium. 

While using LogiCalc, all the data is stored in the main 
memory of the computer until you enter the command which 
will cause LogiCalc to instruct the computer to transfer 
what is in the main memory of the computer onto the 
floppy disk or hard disk. At this time your report is 
stored on a more permanent medium. 
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Output: "Output" is synonymous with "writing". The two most 
common output devices utilized to produce output 
servicable for people are the high-speed printer and the 
cathode ray tube (CRT), commonly known as the screen. 

LogiCalc handles output by providing you with the 
commands to instruct the computer to send reports to 
the terminal screen or to the printer. 
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Care of Diskettes 

There are ten easy rules to remember concerning the care and use 
of your diskettes. Proper handling of the diskettes is a crucial step 
in system maintenance. 

(1) To load the diskette, carefully remove it from its jacket 
and insert it in the direction specified by the computer 
manufacturer. This method insures correctly exposing the 
magnetic surface to the machine. After it clicks into place, 
gently close the disk drive door. 

(2) Always power up the machine before inserting the disk and remove 
it before powering down. 

(3) When not in the drive, the diskette should always be kept in 
its protective jacket. 

(4) When in the envelope, the label on the diskette should always 
face forward. 

(5) Replace the unused disk in its proper location. Never place it 
on top of the terminal or under a phone as this may cause a 
loss of data due to exposure to magnetic fields. 

(6) Never touch the exposed portion of the disk. Doing so will 
cause a loss of data if not more permanent damage to the 
diskette. A good rule to follow is to lightly hold the disk 
only on the label end. 

(7) Use a felt-tip pen rather than a ballpoint pen or pencil to write 
on the label. 

(8) Bending and folding the diskette may damage it. Handle it 
with care. 

(9) Avoid exposing the magnetic surfaces of the disk to excess 
heat, humidity, dust, or cigarette ashes as this may damage 
the disk. 

(10) ALWAYS KEEP A BACKUP OF EVERY IMPORTANT DISK. 
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APPENDIX B 
INSTALLING LOGICALC 



This appendix contains the information needed when installing 
LogiCalc. Before using LogiCalc, you must describe the characteristics 
of your terminal's keyboard so that the system knows exactly what you 
want it to do each time you press a particular key stroke. 

LogiCalc comes with the program LCSET which provides a way to 
configure LogiCalc for your terminal. To begin your configuration 
session, the CP/M prompt appears 



****************************************************************** 

* * 

* A> * 

* * 
********************************************************************* 



Type LCSET <RETURN> in response to the above prompt and the 
system will ask 

********************************************************************* 

* * 

* Normal first-time installation of LogiCalc (Y/n)? * 

* * 

********************************************************************* 



If you are entering a terminal configuration for the first time, 
answer the above question by entering "Y" . If, however, you have 
already entered a terminal configuration and you would like to modify 
it, press "N" . We will now study each option in more detail. 

PART A: FIRST-TIME INSTALLATION 



If "Y" is entered in response to the above prompt, a table 
containing an assortment of common terminal names will appear. Enter 
the corresponding number which identifies your particular terminal. 
For example, let's suppose that your terminal is an LSI ADM-31 (the 
Morrow Designs terminal is similar to this particular terminal). Enter 
"3" in response to the selection prompt. 
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* * 



LogiCalc Terminal Installation Menu A 



A First Menu (#1-24) 

1 LSI ADM- 3 A 

3 LSI ADM-31 

5 Microterm ACT-IV 

7 DEC VT-52 

9 Infoton 1-100 
11 Soroc IQ-120 
13 Microterm ACT-V 
15 Visual 200 
17 Compucolor 800IG 
19 HI9/H89 

21 TRS-80 Model II FMG 
23 Vector Flashwriter II 

Please enter selection; 



B Second Menu (#25-48) 

2 Televideo 950 

4 Hazeltine 1500 

6 Beehive 150 

8 HP 2621 A/P 
10 Soroc IQ-140 
12 Perkin Elmer 550 
14 Televideo 912/920 
16 SWTPC CT-82 
18 TEC 571 

20 TRS-80 Model II P&T 
22 TRS-80 Mod. II Lifeboat 
24 ADDS Regent 



**********************************************************^ 



A prompt then appears to double check your selection 



********************************************************** 

* * 

* Current terminal is ADM-31 * 

* OK (Y/N): * 

* * 

********************************************************************* 



If "N" is entered, it is presumed that you made a mistake 
entering the selection of your terminal name and you are given the 
chance to enter another selection. But, for our example, enter "Y" . 
The following will appear 

********************************************************************* 

* * 

* Are modifications now complete (Y/N)? * 

* * 

********************************************************************* 



If "Y" is pressed, the modifications are assumed complete. If "N" 
is pressed, you are given a chance to modify the normal keyboard 
configuration for an ADM-31. A list of approximately twenty terminal 
keyboard functions is given along with their default values for the 
ADM-31 keyboard. Instead of using the ADM-31 default keyboard 
configuration, you specify the keys which, when pressed, will 
accomplish particular keyboard functions. 
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As an example, let's suppose that your terminal is similar but 
not identical to the ADM-31, so you must modify the ADM * s keyboard 
configuration to adapt it to your terminal. For instance, the key used 
to move the cursor up has a different value on the ADM-31 than it does 
on your machine . 

First, the default value for the key used to move the cursor up 
on the ADM is given along with the inquiry "Change this value?" 

* * 

* Key to move up : * 

* Chars I "E I * 

* Hex 1 05 I * 

* Change this value (Y/N)? * 

* * 



If the key to move the cursor up is the same for both machines, 
we would enter "N" and continue viewing the different key functions 
along with their ADM default values. Since we would like to modify 
this value, however, press "Y" and the following appears 

* * 

* Hit Key or Type *#<hex digitxhex digitx enter > * * 

* * 

*************************************************************** 



Two options are available. First, you may hit the corresponding 
key on your particular keyboard and the corresponding hexadecimal 
value will be entered automatically. Or, you may enter the hexadecimal 
value after pressing "#" and the corresponding character denoting the 
key(s) will be automatically entered (this is particularly useful if 
two keys must be used to activate a particular function, like 
<CTRL+F>. ) 

After pressing the desired key that will be used in the LogiCalc 
program to send the cursor upwards, the character and hexadecimal 
values will change from the ADM's default values displayed above to 
the new values similar to those displayed below: 
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* * 

* Chars ! "P 1 * 

* Hex I 10 I * 

* OK (Y/N)? * 

* * 

**************************************************************** 



If "Y" is pressed, the new value is accepted and you move to the 
next "key function. If "N" is pressed, you are given the chance to 
reenter a value, other than the ADM default value, for the up arrow 
key. 

Once the modifications are complete, a final inquiry is made. 

********************************************************************* 

* * 

* Terminal is ADM-31 * 

* Printer is accessed through normal CP/M LST : device * 

* channel . * 

* * 

* OK (Y/N): * 

* * 

********************************************************************* 



If "N" is pressed, you are returned to the Terminal Installation 
Menu A and allowed to enter a new selection. Answering "Y" completes 
the process, and returns you to the CP/M command A> . What has happened 
is quite simple. LCSET has retrieved the definition of the ADM-31 's 
keyboard configuration from the file LCSET.DAT. (LCSET.DAT contains 
default definitions of the keyboard configurations for all the 
terminals listed on the Installation Menu.) The keyboard configuration 
definition for the ADM-31 along with any modifications is then placed 
in a file called TERMCAP.SYS. 



PART B: MODIFICATION OF EXISTING INSTALLATION 



When there is already information contained in the file 
TERMCAP.SYS (i.e., we answered "N" to the initial question "Normal 
first-time installation of LogiCalc?"), any modifications will be made 
directly to the TERMCAP.SYS file. After a negative answer to the 
primary inquiry, the LogiCalc Installation Options Menu will be 
displayed. 
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************************************************************* 

* * 

* ****LogiCalc Installation Options Menu***** * 

* * 

* A Modification of existing installation * 

* * 

* <ctrl-0> modify database enable * 

* * 

* Please enter selection: * 

* * 

********************************************************************* 



If the <ctrl-0> option is pressed before modifying the existing 
installation, then the modified configuration will be stored in a 
database file and subsequently displayed on the terminal modification 
menu under a specified terminal name and number. 

Whether or not <ctrl-0> was pressed to store modifications, when 
you are ready to modify the existing installation, type "A". A menu 
identical to the LogiCalc Terminal Installation Menu A containing 
twenty-four machine names is given with an added "No Change" option. 
If a terminal is being installed that differs from the terminal 
configuration already entered in TERMCAP.SYS, simply choose the number 
that corresponds to the terminal name on the menu and make any 
necessary modifications to the newly chosen terminal configuration. 
However, if you are not changing terminals but simply modifying the 
terminal configuration presently in TERMCAP.SYS, press "U" (i.e., the 
"No Change" option) and affect any necessary modifications. The actual 
modification process for existing installation is identical to the 
modification process for first-time installation. 
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APPENDIX C 
SAMPLE APPLICATIONS 

This appendix includes three sample applications of reports, 
including a balance sheet, a sales analysis, and a paint cost 
estimation. The appendix includes both the finished report and a 
step-by-step outline of the operations required to create these 
reports. Consequently, these reports will serve as useful practice 
reports for you to gain more confidence in working with LogiCalc. 
These reports are so common that they can also serve as models for you 
to design your own reports. A third benefit of this appendix is the 
extended demonstration of some of the operations available with 
LogiCalc. 

The first example included in this appendix is the balance sheet 
first introduced in section II. 3. We shall duplicate the same 
recalculate steps after we demonstrate how to enter all the 
information needed to create the report. 

I . Enter the report text 

1. Goto Bl and enter: ';' , 'F' , 'W , and '20' to widen the 
column and then enter '/cASSETS' 

2. Goto A4 and enter: ';' , 'F* , "W* , and '28* to widen the 
column and then enter ' /cCURRENT ASSETS ' 

3. Goto A5 and enter 'CASH* 

4. Goto A6 and enter 'ACCOUNTS RECEIVABLE' 

5. Goto A7 and enter 'INVENTORY' 

6. Goto A9 and enter '/cTOTAL CURRENT ASSETS' 

7. Goto A12 and enter '/cTOTAL ASSETS' 

8. Goto A14 and enter '/cTOTAL ASSETS' 

9. Goto B5 and enter '8000000' 

10. Goto B6 and enter '100000' 

11. Goto B7 and enter '5225000' 

12. Goto B8 and enter '/=-' 

13. Goto C9 and enter: ';' , 'F' , 'W' , and '13' to widen the 
column and then enter ' +SUM(B5>B7 ) ' 

14. Goto Cll and enter '/=-' 

15. Goto C12 and enter ' +SUM(B5>B7) ' 

16. Goto C13 and enter '/=-' 

17. Goto D14 and enter: ';' , 'F' , 'W' , and '13' to widen the 
column and then enter ' +SUM(B5>B7 ) ' 

18. Goto D15 and enter '/=' 

'LIABILITIES & EQUITY' 
'/cCURRENT LIABILITIES' 
'ACCOUNTS PAYABLE' 
'NOTES PAYABLE' 

'/cTOTAL CURRENT LIABILITIES' 
'/cTOTAL LIABILITIES' 
'/cOWNERSHIP & EQUITY' 
'CAPITOL* 
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19. 


Goto 


B20 


and 


enter 


20. 


Goto 


A23 


and 


enter 


21. 


Goto 


A24 


and 


enter 


22. 


Goto 


A25 


and 


enter 


23. 


Goto 


A27 


and 


enter 


24. 


Goto 


A30 


and 


enter 


25. 


Goto 


A3 3 


and 


enter 


26. 


Goto 


A34 


and 


enter 



27. 


Goto 


A3 5 


and 


enter 


'NET INCOME' 


28. 


Goto 


A3 7 


and 


enter 


'/cTOTAL WORTH' 


29. 


Goto 


A40 


and 


enter 


/cTOTAL OWNERSHIP & EQUITY' 


30. 


Goto 


A42 


and 


enter 


TOTAL LIABILITIES & EQUITY' 


31. 


Goto 


B24 


and 


enter 


9000* 


32. 


Goto 


B25 


and 


enter 


'4810000' 


33. 


Goto 


B26 


and 


enter 


/=-• 


34. 


Goto 


C27 


and 


enter 


+SUM(B24>B25)' 


35. 


Goto 


C29 


and 


enter 


/=-• 


36. 


Goto 


C30 


and 


enter 


'+SUM(B24>B25)' 


37. 


Goto 


B34 


and 


enter 


8500000' 


38. 


Goto 


B35 


and 


enter 


6000' 


39. 


Goto 


B36 


and 


enter 


/-• 


40. 


Goto 


C37 


and 


enter 


+SUM(B34>B35)' 


41. 


Goto 


C39 


and 


enter ' 


/=-• 


42. 


Goto 


C40 


and 


enter 


+SUM(B34>B35)' 


43. 


Goto 


D42 


and 


enter ' 


+C30 + C40' 


44. 


Goto 


D43 


and 


enter 


/-• 



II. Save the report 

1 . Enter : ' ; ' , ' S ' , ' BALSHEET ' 

III. Recalculate demonstration 

1. Goto B7 and enter '5225850.35' 

2. Goto B24 and enter '9850.35' 

3. Enter: ';' , 'R' , 'A' and watch the total on both sides of 
the report change from 13,325,000.00 to 13,325,850.35. 

IV. Print the report 

1. Enter: ';' , 'P' , <CR> , <CR> , 'D43' , <CR> , '80' , 
'N' , <space> , ' BALANCE SHEET ' , '12-31-81', ' <CR> ' . 
The printout should resemble the following report. 
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The second example report included in this appendix is a job cost 
estimate report. The steps to enter the report and the resulting 
printout are as follows. 



I . Enter the report text 

1. Goto Al and enter: '?' , 'F* 
column and then enter 'Acme Paint, 



'W 
Inc. ' 
Estimation Form 



and ' 20 ' to widen the 



^. Goto A2 and enter 'Cost 

3. Goto A3 and enter */""' 

4. Goto A5 and enter '/^Number of walls: 

5. Goto A7 and enter '/rAvg. wall hgt. : ' 

6. Goto A8 and enter '/rAvg. wall width: 



7. Goto A10 and enter 

8. Goto All and enter 

9. Goto A12 and enter 

10. Goto A14 and enter 

11. Goto A16 and enter 

12. Goto AlB and enter 

13. Goto A20 and enter 

14. Goto A21 and enter 

15. Goto A23 and enter 

16. Goto C5 and enter: 
mode at C5 and then enter 

17. Goto C7 and enter: 

18. Goto C8 and enter: 

19. Goto C10 and enter: 

20. Goto Cll and enter: 

21. Goto C12 and enter 

22. Goto CI 4 and enter 

23 . Goto C16 and enter 

24. Goto C18 and enter 

25. Goto C20 and enter 

26. Goto C21 and enter 

27. Goto C22 and enter 

28. Goto C23 and enter 

29. Goto C24 and enter 



/rPrice paint/gal. : ' 
/rSq. ft. /gal.: ' 
/rApplication speed: 
/rSquare feet=* 
Hourly wages: ' 
/rFixed overhead: ' 
/rMaterial cost=' 
/rLabor cost=' 
/rTOTAL* 



F' 
F' 

•f 

•f 



and 'F' 

'F* and 
•F' and 
•F' and 



to set the form 



'250' 

'+C7 * C8 
' 7 . 89 • 
'17.50' 
•+C14/C11 * 
'+014/012 * 

•/=-• 

'+C18 + C20 

•/==• 



, 'F' 
* C5' 



then enter 
then enter 
then enter 
and then enter 



'12' 

'12' 

'6' 

'300 



C10' 
C16' 

+C21 



II. Save the file 

1. Enter: ';' , 'S' , ' PAINTCOST ' 

III. Enter data by using the Automatic form mode 

1. Enter: ';' , 'A' , '4' , '10' , '10' , '5' , 
'300'. The total will now be automatically recalculated 



IV. Print the report 

1. Enter: ';' , 'P* , <CR> , <CR> , '024' , <CR> , 
'80' , 'N' , <space> , 'SAN DIEGO PROFESSIONAL BLDG. ' , 
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BALANCE SHEET 
12-31-31 

ASSETS 



CURRENT ASSETS 
CASH 

ACCOUNTS RECEIVABLE 
INVENTORY 

TOTAL CURRENT ASSETS 



3000000.00 
100000.00 

5225850.35 



13325850.35 



TOTAL ASSETS 
TOTAL ASSETS 



13325850.35 



13325850.35 



LIABILTTIES & EQUITY 



CURRENT LIABILITIES 
ACCOUNTS PAYABLE 
NOTES PAYABLE 

TOTAL CURRENT LIABILITIES 



9850.35 
4810000.00 



4819350.35 



TOTAL LIABILITIES 



4819850.35 



OWNERSHIP Sc EQUITY 
CAPITOL 
NET INCOME 

TOTAL WORTH 



8500000.00 
6000.00 



3506000.00 



TOTAL OWNERSHIP li EQUITY 
TOTAL LIABILITIES & EQUITY 



^506000.00 



13325850.35 



•Suite 999* , •1-27-81* , <CR> . Your printout should 
resemble the following report. 



SAN DIEGO PROFESSIONAL BLDG. 

Suit* 999 

1-27-81 

Acm* Paint, Inc. 
Cost Estimation Form 



Number of ualls: 4.00 

Av*. wall h«t.: 10.00 

Av». wall width: 10.00 

Price »»aint/»al.: 5.00 

Sn. ft. /sal.: 300.00 

Aplication s^eed: 250.00 

Square feet « 400.00 

HourlY wases: 7.89 

Fixed overhead: 17.50 

Material cost « 6.67 

Labor cost « 12.62 

TOTAL 36.79 
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The third and last example in this appendix is a quarterly sales 
analysis. The steps for entering the report and producing a printout 
are outlined below. 



I . Entering the report text 



1. Goto A5 and enter: ';' , 'F' , 'W' 
column and then enter 'district A' 



and ' 14 ' to widen the 



2. 


Goto A6 and < 


enter ' 


product 1 ' 


3. 


Goto A7 and enter ' 


product 2 • 


4. 


Goto A8 and < 


enter ' 


product 3 ' 


5. 


Goto A10 and 


enter 


•/ctotal* 


6. 


Goto A12 and 


enter 


'district B* 


7. 


Enter; ' ; ' , 


•c , 


'A6>A8' , •A13>A15' 


8. 


Goto A17 and 


enter 


•/ctotal' 


9. 


Goto A19 and 


enter 


'all districts' 


10. 


Enters ' ; ' , 


'C , 


•A6>A8' , •A20>A22' 


11. 


Goto A24 and 


enter 


•/ctotal* 


12. 


Goto A25 and 


enter 


'/ — ' and enter: ';' , 


•C25 


>G25' 






13. 


Goto A28 and 


enter 


'% by product' 


14. 


Enter: ' ? ' , 


•c , 


•A6>A8' , 'A29>A31' 


15. 


Goto A3 3 and 


enter 


'/=+-• 


16. 


Goto A3 5 and 


enter 


' % by district* 


17. 


Goto A36 and 


enter 


'district A' 


18. 


Goto A3 7 and 


enter 


'district B' 


19. 


Goto CI and 


enter ' 


/clsf 


20. 


Goto C2 and 


enter ' 


/cqtr.' and then enter: 


'C2' 


, •D2>G2' 






21. 


Goto C3 and 


enter 


/ — * and then enter: ' ; 


•D3>G3' 






22. 


Goto C6 and 


enter: 


• ; ' , ' F * , ' P • , and • 


decimal precision 


to for column C and then en 


23. 


Goto C7 and 


enter 


100' 


24. 


Goto C8 and < 


enter ' 


200' 


25. 


Goto C9 and 


enter 


/=-' and then enter: '; 


•D9>G9' 






26. 


Goto CI 3 and 


enter 


•100' 


27. 


Goto CI 4 and 


enter 


•90' 


28. 


Goto CI 5 and 


enter 


•165' 


29. 


Enter: ' ; ' , 


•c , 


•C9' , •C16>G16' 


30. 


Goto C20 and 


enter 


'+C6 + C13' 


31. 


Goto C21 and 


enter 


•+C7 + C14' 


32. 


Goto C22 and 


enter 


'+C8 + C15' 


33. 


Enter : ' ; ' , 


•c , 


'C9' , •C23>G23' 


34. 


Goto Dl and 


enter 


'/c2nd* 


35. 


Goto D6 and 


enter: 


' ?• , 'F' , 'P* , and • 


36. 


Goto D7 and 


enter 


110' 


37. 


Goto D8 and 


enter 


'220' 


38. 


Goto D13 and 


enter 


•105' 


39. 


Goto D14 and 


enter 


•103' 


40. 


Goto D15 and 


enter 


*173' 



'A25 



0' to set 
ter '125' 



C3 



the 



'C9' 



0' and then enter '115 
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41. Enter: 



•c 



'C20>C22 ' 



42. Goto El and enter '/c3rd' 

43. Goto E6 and enter: ';' , 'F' 

44. Goto E7 and enter '115' 

45. Goto E8 and enter '210' 

46. Goto El 3 and enter '108' 

47. Goto E14 and enter '100' 

48. Goto E15 and enter '168* 

52. Enter: ';' , 'C , 'D20>D22' 

53. Goto Fl and enter '/c4th' 

: • . 'F' 



•D20>D22' , and 'R' 

'P' , and '0' and then enter '130' 



'E20>E22' , and 'R' 

'P' , and '0' and then enter '120' 



'F20>F22' , and 'R' 

' P ' , and ' ' and then enter 



54 . Goto F6 and enter : ' ; ' . 

55. Goto F7 and enter '108' 

56. Goto F8 and enter '215' 

57. Goto F13 and enter '112' 

58. Goto F14 and enter '105' 

59. Goto F15 and enter '179' 

60. Enter: ';' , 'C , 'E20>E22' 

61. Goto G6 and enter: ';' , 'F' 
•+SUM(C6>F6)' 

62. Enter: ';' , 'C , 'G6' , 'G7>G8' , and 'R' 

63. Enter: ';' , 'C , 'G6>G8' , •G13>G15' , and 'R' 

64. Enter: ';','€', 'G13>G15' , G20>G22' , and 'R' 

65. Goto C10 and enter ' +SUM(C6>C8) ' 

66. Enter: ';•,'€', '010' , 'D10>G10' 

67. Goto C17 and enter ' +SUM(C13>C15 ) ' 

68. Enter: ';' , 'C , 'C17' , 'D17>G17' , and 'R* 

69. Goto C24 and enter ' +SUM(C20>C22) ' 

70. Enter: ';','€', '024' , •D24>G24' , and 'R' 

71. Goto C29 and enter '+020/024 * 100' and then enter: ';' , 'F' 
'P' , and 'El' to set the decimal precision to 1 place 

72. Enter: ';' , 'O' , '029' , •D29>G29' , and 'R' and then goto 
D29, E29, F29, and G29 and at each location enter: '?' , 'F' , 'P' 
and 'El' 

73. Goto 030 and enter '+021/024 * 100' and then enter: ';' , 'F' 
'P* , and 'El* 

74. Enter: ';' , '0' , '030' , 'D30>G30' , and 'R' and then goto 
D30, E30, F30, and G30 and at each location enter: ';' , 'F' , 'P' 
and 'El' 

75. Goto 031 
'P' , and 'El 

76. Enter: ' 
D31, E31, F31 
and 'El' 

77. Goto 036 
•P' , and 'El 

78. Enter: ' 
D36, E36, F36 
and 'El' 

79. Goto 037 
'P' , and 'El 

80. Enter: ' 
D37, E37, F37 
and 'El' 



and enter '+022/024 * 100' and then enter: ';' , 'F' , 

' , '0' , '031' , 'D31>G31' , and 'R' and then goto 
and G31 and at each location enter: ';' , 'F' , 'P' , 

and enter '+010/024 * 100' and then enter: ';' , 'F' , 

' , 'O' , '036' , •D36>G36' , and 'R' and then goto 
and G36 and at each location enter: ';' , 'F' , 'P' , 

and enter '017/024 * 100' and then enter: ';' , 'F' , 

' , '0' , '037' , 'D37>G37' , and 'R' and then goto 
and G37 and at each location enter: ';' , 'F' , 'P' , 
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II. Save the report 

1. Enter: '?' , 'S' , 'QTRSALES' 



III. Print the report 

1. Enter: ' ? ' , 'P' 
'132' , 'N' , <space> 
'Beta IV Corporation' 
the following: 



<CR> , <CR> , '037' , <CR> , 
'Sales Analysis by Quarter 1979' , 
<CR> . Your printout should resemble 



district A 
rrodoct 1 
rr«4«ct 2 
product 3 

toUl 

district B 
frtdvct 1 
n^dttct 2 
product 3 

totil 

ill districts 
product 1 
product 2 
product 3 

tot&I 



2 br product 
product 1 
product 2 
product 3 

< I I ( t I I 

t bY district 
district A> 
district B 



S&tes AtaWsis br thMrtcr 1979 
Bota IV Corporitioft 




• 


iff 


^ 


3rd 
ntr 


4th 
^r 


fill 

YMT 


125 
100 
20O 


115 
110 
220 


.130 
115 
210 


120 

loe 

215 


490 
433 

845 


425 


445 


455 


443 


1768 


90 
US 


106 
103 
173 


108 
100 
168 


112 
105 
179 


425 
398 
685 


355 


381 


376 


396 


1506 


225 
190 
365 


220 
213 
393 

826 


238 
215 
378 

831 


232 
213 
394 

839 


915 

831 

1530 


780 


3276 


28.8 
24.4 
46.8 


26.6 
25.8 
47.6 


28.6 
25.9 
45.5 


27.7 
25.4 
47.0 


27.9 
25.4 
46.7 


54.5 
45.5 


53.9 
46.1 


54.8 
45.2 


52.8 
47.2 


54.0 
46.0 
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APPENDIX D 
COMMAND INDEX 

This appendix includes an alphabetical and symbolical listing of 
the function and command operations available with LogiCalc and a 
short explanation of the operation along with a reference to the 
section in this manual which describes the operation in detail. 



7 A = automatic form mode for entering data in specific entries 11.25 

;C = copy entry (or range of entries) into an entry (or range) II. 8 

;D = delete an entry, column, row, or entire array 11.23 

;E = moves the array so cursor location is upper left corner 11.14 

;F = changes column width II. 5 

changes decimal precision 11.10 

changes form mode 11.25 

;G = move the cursor to specified location II. 6 

;H = displays the help file for handy reminders 11.33 

;I = insert a row or column 11.22 

;L = load a file that has been saved into the LogiCalc array 11.30 

;M = merge a saved file with current contents of array 11.21 

;0 = toggles the order of evaluation for the Recalculate command; 

sets automatic rounding, advancement, and recalculation to on 11.20 

7? = prints the given section of the array 11.26 

11.27 

?Q = exits the LogiCalc program 11.32 

7R = recomputes an entry or all formulas in the array 11.19 

7S = saves the contents of the array onto the disk 11.12 

7T = enables the Text Editor to correct text data entries II. 4 

7W = shows you the row and column headings for the entry 

where the cursor is presently located II.16A 

7= = locks in column and/or row headings for entire array 

(an Extended What command) II.16B 

7? = informs you of the amount of storage space still available 11.13 
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;* = extends the window into the LogiCalc array to 15 rows from 

the standard 10 row display 11.30 

if(i) = allows you to enter a user defined function in one 

variable. The expression to evaluate replaces f ( 1 ) and 

the variable data you will enter replaces the 'I 11.17 

+sum( range of entries) = sums the values contained within the 

given range 11.17 

+avg( range of entries) = computes the average of the values 

contained within the given range 11.17 

+cnt( range of entries) = returns the number of numeric entries 

contained within the given range 11.17 

+max( range of entries) = returns the maximum value contained 

within the given range 11.17 

+min( range of entries) = returns the minimum value contained 

within the given range 11.17 

+regr( range of entries, first coordinate of another range) = 

computes a linear regression line and returns the average 

of the second range (dependent variable) 11.29 

+proj( value) = inserts a value for independent variable into the 
regression equation and returns the predicted value (the 
dependent variable) 11.29 

+depd( value) = inserts a value for the dependent variable into 
the regression equation and solves for and returns the 
best estimate for the independent variable 11.29 

+slope() = returns the slope of the regression equation which 

may be used to evaluate the degree of correlation 11.29 

/c = center justifies a text entry II. 4 

/l = left justifies a text entry II. 4 

/r = right justifies a text entry II. 4 

/= = will repeat the characters following = throughout the entry II. 7 

/p ~ printing will execute a form feed. Must be in column A 11.28 

\ = allows insertion of comment into numeric entry location 11.18 

@ = enters cursor location into current indication 11.15 

= toggles text type between text and numeric 11.11 
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^E= moves the cursor up one location II. 2 

^X= moves the cursor down one location II. 2 

*S= moves the cursor to the left one location II. 2 

^D= moves the cursor to the right one location II. 2 

<esc> == aborts a command II. 5 

<CR> = enters data if something on edit line or moves the cursor 

to the right one location or abhorts a command 11.2,11.5 

<TAB> = moves the cursor to specified location. Same as goto command II. 2 

[arithmetic expression]? = evaluates the expression without entering 

it into the array II. 1 
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APPENDIX E 
ERROR MESSAGES 

This appendix includes a list of the error messages that may 
occur during LogiCalc program 



bad coord — coordinate entered cannot be used for intended purpose 
bad form length — specified form length is not within required 
range (1 . . 66 ) 

bad range coord — range of coordinates cannot be used for intended 
purpose 

can't create — not enough memory to set format precision 
can't open — not enough space on disk or disk needs crunching 
can't open file — not enough room to open file on disk 
couldn't read SYSTEM. MI SCINFO — system could not read a necessary 
file; related to hardware. Need to get proper version of file 

DATA IS PROBABLY DAMAGED — from entering too long of a report and 

there was not enough memory 
data too wide — specified printing section is too wide for specified 

printing width 
Delete character is underscore ("___") — certain machines will have 

the underscore key as their delete key 

ERROR -> <expression>? — system could not interpret entry correctly 
ERROR would delete ref(s) at <coord> — specified deletion would 

eliminate data on which other formulas are dependent, so formulas 

must first be changed 

FATAL ERROR: not on disk — disk is missing an important LogiCalc 

file and cannot operate until it is on the disk 
FILEWRITE ERROR — system had trouble writing file to the disk 

math op error 

numeric overflow — space is not large enough for intended operation 
math op error 

divide by zero — expression would lead to a value being divided by 
0, which is undefined 
MEMORY IS TOO LOW — not enough room to make the intended insertion 
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inl — column is not wide enough 

no form flags — no automatic form modes have been set 

not along row/column — specified copy is not in a straight vertical 

or straight horizontal line 
not ok — password is not correct 

OUT OF MEMORY — no memory left; something must be deleted 

Prec. must be 0..12 — precision entry is not within required range 

READ ERROR — there are bad blocks where the file is stored 

sizes don't agree — number of coordinates you are copying from and 
number of coordinates you are copying to are different 

Width must be 3. .63 — column width entry is not within required range 

WRITE ERROR — disk gets full while writing a file 

write error, not the same — second password is not the same as the 
first password 

write error <file> not found — file does not exist as entered 

write error l/O — disk needs crunching 

write error Close — disk needs crunching 

write error end>start — in saving a partial file, the top left coordin- 
ate must come before the bottom right coordinate 

write error bad coord — invalid coordinate entered 

WRITE CLOSE ERROR — diskette is wrong or insufficient room 

EVALUATION ERRORS 

— value range error: 

math overflow 

divide by zero 

function cannot evaluate value entered 

1 — illegal coordinate or wrong coordinate format 

2 — range is not a row or column 

3 — missing a ' ( ' or ' ) ' 

4 — unknown function, function typed incorrectly 

6 — terminal expression is illegal 

7 — illegal characters at the end of the line 

8 — number is not in correct form 

9 — error in regression values 

12 — too many parenthetical levels 
255 — illegal value in REGR function 
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READERS* COMMENTS 

In order to provide you with the best possible products, we have 
included the following evaluation form. We would appreciate hearing 
your thoughts on both the LogiCalc program and the user's manual. When 
you have completed the evaluation, please mail to: 



Software Products International 
10343 Roselle 
San Diego, Ca. 92121 
attn: LogiCalc Evaluation 

Thank you I jdk/je 

LogiCalc Program 

1. What is your overall impression of the LogiCalc program? 

Excellent Very Good Good Fair Poor 

2. Was the program useful for your applications? 

Excellent Very Good Good Fair Poor 



3. How would you rate the reliability of the program as far as 
working the way it should? 

Excellent Very Good Good Fair Poor 

4. Was the program easy to learn and use? 

Excellent Very Good Good Fair Poor 

5. Did the program include all the features you feel were 
necessary for a financial modeling system? 

Excellent Very Good Good Fair Poor 

6. How do you think LogiCalc compares with its competition? 

Excellent Very Good Good Fair Poor 

Additional Comments : 



LOGICALC COMMANDS 

Following is a list of the Logicalc commands along with a brief 
description and the section number in the manual which describes the 
command in greater detail. 

;A = Automatic form mode for automatic entry of variable data 11.25 

;C = Copy entry (or range of entries) into an entry (or range) II. 8 

;D = Delete an entry, column, row, or entire array 11.23 

;E = moves the array so cursor location is upper left corner 11.14 

;F = changes column width II. 5 

changes decimal precision 11.10 

changes form mode 11.25 

G = move the cursor to entry you specify (same as <tab> ) II. 6 

H = displays the help file for handy reminders 11.33 

I = Insert a row or column 11.22 

L = load an already saved file into the Logicalc array 11.30 

M = merge a saved file with current contents of array 11.21 

= toggles the order of evaluation for the Recalculate command 11.20 

P = prints the entire model or the portion you specify 11.26,11.27 

Q = exits the Logicalc program 11.32 

R = recomputes an entry or all formulas in the array 11.19 

S = saves the portion of the model you specify onto the disk, 

with or without password protection. 11.12 

?T = enables the Text Editor to correct text data entries II. 4 

;U = presents a directory listing of the entire disk or of 

all Logicalc files on the disk volume 11.35 

;W = shows you the row and column headings for the entry 

where the cursor is presently located II.16A 

;= = locks in column and/or row headings for entire array 

(an extended What command) II.16B 



•? = 



informs you of the amount of storage space still available 11.13 



;* = extends the window into the Logicalc array to 15 rows from 

the standard 10 row display 11.30 



[arithmetic expression]? = evaluates the expression without entering 

it into the array II. 1 

/c = center justifies a text entry II. 4 

/I = left justifies a text entry II. 4 

/r = right justifies a text entry II. 4 

/= = will repeat the characters following = throughout the entry II. 7 

/p = printing will execute a form feed. Must be in column A 11.28 

\ = allows insertion of comment into numeric entry location 11.18 

@ = enters cursor location into current indication once one 

character has been entered on the edit line 11.15 

= toggles text type between text and numeric 11.11 

<esc> = aborts a command II. 5 

Available built-in math functions include the following: 

+sum( range of entries) = sums the values contained within the 

given range [format example sum(Al>A6)] 11.17 

+avg( range of entries) = computes the average of the values 

contained within the given range 11.17 

+cnt( range of entries) = returns the number of numeric entries 

contained within the given range 11.17 

+max( range of entries) = returns the maximum value contained 

within the given range 11.17 

+min( range of entries) = returns the minimum value contained 

within the given range 11.17 

+regr( range of entries, first coordinate of another range) = 

computes a linear regression line and returns the average 

of the second range (dependent variable) 

[format example regr (A1>A6,C1 ) ] 11.29 

+proj( value) = inserts a value for independent variable into the 
regression equation and returns the predicted value (the 
dependent variable) [format example proj(D6)] 11.29 



+depd( value) = inserts a value for the dependent variable into 
the regression equation and solves for and returns the 
best estimate for the independent variable 11.29 

+slope() = returns the slope of the regression equation which 

may be used to evaluate the degree of correlation 11.29 

If(l) = allows you to enter a user defined function in one 

variable. The expression to evaluate replaces f ( 1 ) and 

the variable data you will enter replaces the 'I' 11.17 

conditional expression format — condition: true result: false result 
where either of the results may be a numeric expression or a string 
of five or less characters, [format example +Al<A6:4*D4:C7/3 . 5 or 
+A1 <A6 : " true ":" false " ] 11.24 

OVERVIEW 

Logicalc's "electronic spread sheet measures 255 rows by 127 
columns. The number of entries which may be used will depend on the 
amount of main memory for your computer. Locations on the "electronic 
spread sheet" may be referenced by a coordinate; i.e., a column letter 
and a row number. At these coordinates you may enter data items, 
either text or numeric. You may move from one coordinate to another 
using the cursor controls. Coordinates which contain numerical values 
may be combined to form arithmetic or conditional expressions. The sum 
total of your data items comprises your model. This model may be 
altered, saved to the disk for future use or printed out. 

CURSOR CONTROLS 

To move the cursor around the "electronic spread sheet", use the 
following keys (or their equivalent on your computer) . 

key result 



^E move up one row 
'^X move down one row 
^D move right one column 
^S move left one column 
<TAB> move anywhere by entering the 
appropriate coordinate 

DATA ENTRY 

To enter data (text or numeric) move the cursor to the desired 
coordinate, type in the data and type <CR> . If the data type is wrong 
(text instead of numeric), type ' '^ ' to switch the data type. Results 
of a formula will be displayed in the array, not the formula itself. 



